:root{
  /* typography */
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  --radius:16px;
  /* scales */
  --fs-1:12px;
  --fs-2:14px;
  --fs-3:16px;
  --fs-4:18px;
  --fs-5:22px;
  --lh-1:1.2;
  --lh-2:1.4;
  --lh-3:1.6;

  --sp-1:4px;
  --sp-2:8px;
  --sp-3:12px;
  --sp-4:16px;
  --sp-5:20px;
  --sp-6:24px;
  --sp-7:32px;
  --sp-8:40px;

  --radius-sm:12px;
  --radius-md:16px;
  --radius-lg:22px;

  --shadow-sm:0 6px 16px rgba(11,18,32,.10);
  --shadow-md:0 10px 24px rgba(11,18,32,.10);

  --textSoft:var(--muted);
  --borderSoft:var(--border);
  --focusRingColor:rgba(22,75,138,.22);
  --focusRing:0 0 0 3px var(--focusRingColor);

  /* Theme G (Cloud Dancer + Oxford) — LIGHT by default */
  color-scheme: light dark;

  --bg:#F7F8FA;
  --card:#FFFFFF;
  --surface2:#EEF2F6;

  --text:#0B1220;
  --muted:#4B5563;

  --border:#D6DDE6;
  --shadow:0 10px 24px rgba(11,18,32,.10);

  --accent:#164B8A;
  --accentText:#FFFFFF;
  --accentSoftBg:rgba(22,75,138,.10);
  --accentSoftBorder:rgba(22,75,138,.28);
  --accentA10:rgba(22,75,138,.10);
  --accentA12:rgba(22,75,138,.12);
  --accentA18:rgba(22,75,138,.18);
  --accentA22:rgba(22,75,138,.22);
  --accentA28:rgba(22,75,138,.28);
  --accentA45:rgba(22,75,138,.45);
  --accentA55:rgba(22,75,138,.55);

  --barInset:rgba(255,255,255,.10);


  --danger:#E5484D;
  --dangerBg:rgba(229,72,77,.10);
  --dangerBorder:rgba(229,72,77,.35);
  --dangerText:#8A1F24;

  --warning:#F2A541;
  --success:#20B486;

  --dotPast:#9AA7B2;
  --dotInset:rgba(11,18,32,.10);

  --inputBg:#EEF2F6;
  --navBg:rgba(247,248,250,.78);
  --toastBg:rgba(255,255,255,.88);

  --shimmer:rgba(11,18,32,.07);
}

/* System dark (when user didn't force light) */
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]) {
    --bg:#090F1D;
    --card:#0E1730;
    --surface2:#0B1328;

    --text:#E8ECF5;
    --muted:#B3BDD6;

    --border:#1C2C55;
    --shadow:0 10px 30px rgba(0,0,0,.35);

    --accent:#3C78C8;
    --accentText:#081022;
    --accentSoftBg:rgba(60,120,200,.18);
    --accentSoftBorder:rgba(60,120,200,.45);
    --focusRingColor:rgba(60,120,200,.30);

    --accentA10:rgba(60,120,200,.10);
    --accentA12:rgba(60,120,200,.22);
    --accentA18:rgba(60,120,200,.28);
    --accentA22:rgba(60,120,200,.22);
    --accentA28:rgba(60,120,200,.28);
    --accentA45:rgba(60,120,200,.45);
    --accentA55:rgba(60,120,200,.55);

    --barInset:rgba(0,0,0,.18);


    --danger:#FF5B5B;
    --dangerBg:rgba(255,91,91,.12);
    --dangerBorder:rgba(255,91,91,.35);
    --dangerText:#FFD1D1;

    --warning:#FFCA5A;
    --success:#34D399;

    --dotPast:#6C7A8B;
    --dotInset:rgba(255,255,255,.06);

    --inputBg:rgba(0,0,0,.18);
    --navBg:rgba(9,15,29,.72);
    --toastBg:rgba(11,18,32,.68);

    --shimmer:rgba(255,255,255,.10);
  }
}

/* Forced dark */
:root[data-theme="dark"]{
  --bg:#090F1D;
  --card:#0E1730;
  --surface2:#0B1328;

  --text:#E8ECF5;
  --muted:#B3BDD6;

  --border:#1C2C55;
  --shadow:0 10px 30px rgba(0,0,0,.35);

  --accent:#3C78C8;
  --accentText:#081022;
  --accentSoftBg:rgba(60,120,200,.18);
  --accentSoftBorder:rgba(60,120,200,.45);
  --focusRingColor:rgba(60,120,200,.30);

  --accentA10:rgba(60,120,200,.10);
  --accentA12:rgba(60,120,200,.22);
  --accentA18:rgba(60,120,200,.28);
  --accentA22:rgba(60,120,200,.22);
  --accentA28:rgba(60,120,200,.28);
  --accentA45:rgba(60,120,200,.45);
  --accentA55:rgba(60,120,200,.55);

  --barInset:rgba(0,0,0,.18);


  --danger:#FF5B5B;
  --dangerBg:rgba(255,91,91,.12);
  --dangerBorder:rgba(255,91,91,.35);
  --dangerText:#FFD1D1;

  --warning:#FFCA5A;
  --success:#34D399;

  --dotPast:#6C7A8B;
  --dotInset:rgba(255,255,255,.06);

  --inputBg:rgba(0,0,0,.18);
  --navBg:rgba(9,15,29,.72);
  --toastBg:rgba(11,18,32,.68);

  --shimmer:rgba(255,255,255,.10);
}


/* HookahPlace theme (brand: black + red neon) */
:root[data-theme="hookahplace"]{
  color-scheme: dark;

  --bg:#070707;
  --card:#111111;
  --surface2:#151515;

  --text:#F5F5F5;
  --muted:#B7B7B7;

  --border:#262626;
  --shadow:0 10px 30px rgba(0,0,0,.55);

  --accent:#E00000;
  --accentText:#FFFFFF;
  --accentSoftBg:rgba(224,0,0,.14);
  --accentSoftBorder:rgba(224,0,0,.40);

  --focusRingColor:rgba(224,0,0,.28);

  --danger:#FF5B5B;
  --dangerBg:rgba(255,91,91,.12);
  --dangerBorder:rgba(255,91,91,.35);
  --dangerText:#FFD1D1;

  --warning:#FFCA5A;
  --success:#34D399;

  --dotPast:#6C7A8B;
  --dotInset:rgba(255,255,255,.06);

  --inputBg:rgba(255,255,255,.06);
  --navBg:rgba(7,7,7,.72);
  --toastBg:rgba(15,15,15,.74);

  --shimmer:rgba(255,255,255,.10);

  --accentA10:rgba(224,0,0,.10);
  --accentA12:rgba(224,0,0,.12);
  --accentA18:rgba(224,0,0,.18);
  --accentA22:rgba(224,0,0,.22);
  --accentA28:rgba(224,0,0,.28);
  --accentA45:rgba(224,0,0,.45);
  --accentA55:rgba(224,0,0,.55);

  --barInset:rgba(0,0,0,.22);

  --calLineAlpha:.18;
  --calLineBorderAlpha:.45;
}

html[data-theme="hookahplace"] body{
  background:
    radial-gradient(900px 420px at 20% 115%, rgba(224,0,0,.22), rgba(224,0,0,0) 60%),
    radial-gradient(700px 360px at 85% 10%, rgba(224,0,0,.16), rgba(224,0,0,0) 55%),
    var(--bg);
}

*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--text);padding:16px 14px calc(84px + env(safe-area-inset-bottom))}
.container{max-width:980px;margin:0 auto}

.topbar{display:flex;justify-content:flex-start;align-items:center;gap:12px;flex-wrap:nowrap;margin-bottom:16px;min-height:44px; padding:0 4px}
.brand{min-width:0;flex:1 1 auto;display:flex;align-items:center;gap:12px}
.title{min-width:0;line-height:1.15}
.title b{display:block;font-size:16px}
.title div{font-size:12px;color:var(--muted);margin-top:2px}
.userpill{display:none !important}

.logo{width:40px;height:40px;flex:0 0 auto;border-radius:0;background:center / contain no-repeat url("/logo.png");filter:drop-shadow(0 8px 16px rgba(0,0,0,.18))}
.topbar__spacer{display:none}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}
.itemcard{border:1px solid var(--border);border-radius:14px;padding:14px;background:var(--surface2)}

.grid{display:grid;gap:12px;grid-template-columns:1.1fr .9fr}
.grid2{grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:900px){.grid{grid-template-columns:1fr}.grid2{grid-template-columns:1fr}}

.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.muted{color:var(--muted);font-size:13px;line-height:1.35}
.small{font-size:12px;color:var(--muted)}
.mono{font-family:var(--mono);font-size:12px;color:var(--muted)}

.btn{text-decoration:none;border:1px solid var(--border);cursor:pointer;padding:11px 12px;border-radius:12px;background:var(--surface2);color:var(--text);font-weight:800}
.btn.primary{background:var(--accent);color:var(--accentText);border-color:transparent}
.btn.danger{background:var(--dangerBg);border-color:var(--dangerBorder);color:var(--dangerText)}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn:active{transform:translateY(1px)}
.btn.sm{padding:8px 10px;font-size:12px}

a.link{color:var(--accent);text-decoration:none;font-weight:800}

input:not([type="checkbox"]):not([type="radio"]),select,textarea{
  width:100%;
  max-width:100%;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0)), var(--inputBg);
  color:var(--text);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
  transition:border-color .16s ease, box-shadow .16s ease, background .16s ease, transform .16s ease;
}
input[type="text"],input[type="search"],input[type="number"],input[type="date"],input[type="month"],input[type="tel"],input[type="password"],input[type="email"]{min-width:min(220px,100%)}
select{
  min-width:min(180px,100%);
  appearance:none;
  -webkit-appearance:none;
  padding-right:40px;
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0)),
    linear-gradient(45deg, transparent 50%, var(--muted) 50%),
    linear-gradient(135deg, var(--muted) 50%, transparent 50%);
  background-position:
    0 0,
    calc(100% - 18px) calc(50% - 2px),
    calc(100% - 12px) calc(50% - 2px);
  background-size:
    auto,
    6px 6px,
    6px 6px;
  background-repeat:no-repeat;
}
select[multiple]{padding-right:12px;background-image:linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));background-position:0 0;background-size:auto;background-repeat:no-repeat;}
select option{color:#0B1220}
textarea{
  min-height:96px;
  resize:none;
  outline:none;
}
label > input:not([type="checkbox"]):not([type="radio"]),
label > select,
label > textarea{
  margin-top:6px;
}
input:not([type="checkbox"]):not([type="radio"]):hover,
select:hover,
textarea:hover{
  border-color:var(--accentSoftBorder);
}
input:not([type="checkbox"]):not([type="radio"]):focus,select:focus,textarea:focus{
  outline:none;
  border-color:var(--accentA45);
  box-shadow:var(--focusRing), inset 0 1px 0 rgba(255,255,255,.05);
}
input:not([type="checkbox"]):not([type="radio"])::placeholder,
textarea::placeholder{
  color:var(--muted);
  opacity:.88;
}

@media (max-width:420px){
  input:not([type="checkbox"]):not([type="radio"]),select{min-width:0;width:100%}
}


/* checkbox inputs */
input[type="checkbox"],input[type="radio"]{
  -webkit-appearance:auto;
  appearance:auto;
  padding:0;
  border:none;
  background:transparent;
  min-width:0;
  width:18px;
  min-height:18px;
  height:18px;
  margin:0;
  flex:0 0 18px;
  accent-color:var(--accent);
}

.chk,
.checkline{display:inline-flex;align-items:center;gap:10px;cursor:pointer;user-select:none;vertical-align:middle;max-width:100%}
.chk .muted,
.checkline .muted{margin:0}
.chk input,
.checkline input{flex:0 0 18px}
.checkline{font-weight:600;color:var(--text)}
.checkline--block{display:flex;width:100%}
.checkline__text{min-width:0}
.badge input[type="checkbox"]{margin-right:6px}

.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.section-title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.section-actions{display:flex;justify-content:flex-end;margin-top:8px}
.list{margin-top:12px;display:grid;gap:10px}

.list__row{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--card)}
.list__main{min-width:0}
.list-row{border:1px solid var(--border);border-radius:14px;padding:12px;background:var(--card)}
.list-row__main{min-width:0}
.list-row__meta{color:var(--textSoft);font-size:var(--fs-1)}
.divider{height:1px;background:var(--border);border-radius:999px;opacity:.9}

.sep{height:1px;background:var(--border);border-radius:999px;opacity:.9}

.day-salary{display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:900;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface2)}

.nav{position:fixed;left:0;right:0;bottom:0;padding:10px 12px calc(10px + env(safe-area-inset-bottom));background:var(--navBg);backdrop-filter:blur(10px);border-top:1px solid var(--border)}
.nav .wrap{max-width:980px;margin:0 auto}
.nav .wrap #nav{display:flex;gap:10px;align-items:stretch;justify-content:space-between;width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;white-space:nowrap;padding-bottom:2px}
.nav .wrap #nav::-webkit-scrollbar{height:0}
.nav a{flex:0 0 auto;white-space:nowrap;text-align:center;padding:10px 12px;border-radius:14px;border:1px solid var(--border);color:var(--muted);text-decoration:none;font-weight:900;background:var(--surface2)}
.nav a.active{color:var(--accentText);background:var(--accent);border-color:transparent}
.nav a.icon{flex:0 0 auto;width:48px;padding:10px 0}

.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:calc(76px + env(safe-area-inset-bottom));width:min(560px, calc(100vw - 28px));border-radius:14px;border:1px solid var(--border);background:var(--toastBg);backdrop-filter:blur(10px);box-shadow:var(--shadow);padding:10px 12px;display:none}
.toast.show{display:block}
.toast.ok{border-color:rgba(80,255,140,.35)}
.toast.warn{border-color:rgba(255,200,80,.35)}
.toast.err{border-color:var(--dangerBorder)}
.toast__text{font-size:13px;color:var(--text)}

.modal{position:fixed;inset:0;display:none;z-index:10000}
.modal.open{display:block}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55);z-index:1}
.modal__panel{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(920px, calc(100vw - 28px));max-height:min(80vh, 720px);overflow:auto;border-radius:18px;background:var(--card);border:1px solid var(--border);box-shadow:var(--shadow);padding:14px;z-index:2}
.modal__head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.modal__title{font-weight:900}

/* Generic list rows (used in catalogs: departments/payment methods/KPI) */
.listrow{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;border-bottom:1px solid var(--border);padding:10px 0}
.listrow__left{flex:1 1 auto;min-width:0}
.listrow__meta{margin-top:4px;overflow-wrap:anywhere;word-break:break-word}


.json{margin:12px 0 0;padding:12px;border-radius:14px;border:1px solid var(--border);background:var(--surface2);font-family:var(--mono);font-size:12px;white-space:pre;overflow:auto}

.skeleton{border-radius:14px;border:1px solid var(--border);background:var(--surface2);height:64px;position:relative;overflow:hidden}
.skeleton::after{content:"";position:absolute;inset:-40px;background:linear-gradient(90deg, transparent, var(--shimmer), transparent);transform:translateX(-60%);animation: shimmer 1.1s infinite}
@keyframes shimmer{100%{transform:translateX(60%)}}

/* Venue switcher */
.venue-switch{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface2)}
.venue-switch__label{font-size:12px;color:var(--muted)}
.venue-switch__select{
  background:transparent;color:var(--text);
  border:none;outline:none;
  font-size:12px;
  padding:2px 0;
  max-width:240px;
}

/* Splash / loading */
.splash{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg);z-index:9999}
.splash__logo{width:84px;height:84px;background:center / contain no-repeat url("/logo.png");filter:drop-shadow(0 10px 24px rgba(0,0,0,.22));margin-bottom:14px}
.spinner{width:34px;height:34px;border-radius:50%;border:3px solid rgba(127,127,127,.25);border-top-color:var(--accent);animation:spin 1s linear infinite;margin-top:10px}
@keyframes spin{to{transform:rotate(360deg)}}

/* Shifts calendar */
.cal{width:100%}
.cal-head, .cal-body{display:grid;grid-template-columns:repeat(7, minmax(0, 1fr));gap:8px}
.cal-head{margin-bottom:6px}
.cal-hcell{font-size:12px;color:var(--muted);text-align:center;padding:6px 0;opacity:.85}

.cal-cell{
  min-width:0;
  width:100%;
  text-align:left;
  border:1px solid var(--border);
  background:var(--surface2);
  border-radius:14px;
  padding:8px;
  min-height:74px;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  gap:6px;
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
  will-change:transform;
}
.cal-cell:active{transform:scale(.995)}
.cal-cell--out{opacity:.45}

.cal-cell--selected{
  box-shadow:0 0 0 2px var(--accent) inset, 0 10px 24px rgba(0,0,0,.08);
}
.cal-cell--today{outline:2px solid var(--accent);outline-offset:-2px}

.cal-daynum{font-weight:700;font-size:13px;line-height:1;color:var(--muted)}
.cal-badges{
  min-width:0;display:flex;flex-direction:column;gap:4px;min-width:0;margin-top:4px}

.report-legend{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:center}
.report-legend__item{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);line-height:1.3}
.report-legend__swatch{width:14px;height:14px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);flex:0 0 auto}
.report-legend__swatch--closed{background:rgba(52,199,89,.18);border-color:rgba(52,199,89,.38)}
.report-legend__swatch--draft{background:rgba(255,204,0,.20);border-color:rgba(255,204,0,.42)}
.report-legend__swatch--overdue{background:rgba(255,59,48,.16);border-color:rgba(255,59,48,.34)}

.badge{
  max-width:100%;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  font-size:11px;
  line-height:1.15;
  padding:4px 6px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface2);
}
.badge--me{border-color:var(--accentSoftBorder);background:var(--accentSoftBg)}
.badge--more{opacity:.85}

.cal-line{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:10px;
  font-weight:800;
  line-height:1.2;
  padding:3px 7px;
  border-radius:999px;
  background:var(--card);
  border:1px solid var(--border);
  color:var(--text);
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
}


.cal-line__text{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.cal-line--more{
  justify-content:center;
  font-weight:900;
  letter-spacing:.06em;
}


/* Colorized cal-line (interval colors) */
:root{ --calLineAlpha:.10; --calLineBorderAlpha:.28; }
@media (prefers-color-scheme: dark){
  :root:not([data-theme="light"]){ --calLineAlpha:.18; --calLineBorderAlpha:.45; }
}
:root[data-theme="dark"],:root[data-theme="hookahplace"]{ --calLineAlpha:.18; --calLineBorderAlpha:.45; }

.cal-line[data-icolor="1"]{
  background: rgba(var(--line-rgb), var(--calLineAlpha));
  border-color: rgba(var(--line-rgb), var(--calLineBorderAlpha));
  box-shadow: inset 3px 0 0 rgb(var(--line-rgb));
}

.cal-cell.is-expanded{
  z-index:50;
  grid-column:span 3;
  grid-row:span 2;
  transform:scale(1.06);
  box-shadow:0 14px 40px rgba(0,0,0,.25);
  animation: pop .18s ease-out;
}
@keyframes pop{0%{transform:scale(1.00)}60%{transform:scale(1.07)}100%{transform:scale(1.06)}}

/* Dots (interval colors) */
/* dotrow removed */

/* Small interval marker (used in day modal / shift cards) */
.intchip{display:inline-block;width:10px;height:10px;border-radius:999px;margin-right:8px;vertical-align:middle;box-shadow:0 0 0 1px var(--dotInset) inset}

@media (max-width:380px){
  .cal-head,.cal-body{gap:6px}
  .cal-cell{padding:7px;min-height:68px}
  .badge{font-size:10px}
}

/* Toggle blocks / switches */
/* Segmented control: shifts mode (Все / Только мои / Общий) */
.shift-toggle{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface2);
  -webkit-tap-highlight-color:transparent;
}
.shift-toggle button{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--muted);
  font-weight:800;
  font-size:12px;
  line-height:1;
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
  transition:background .15s ease, color .15s ease, transform .12s ease;
  user-select:none;
}
.shift-toggle button:active{transform:scale(.99)}
.shift-toggle button:hover{background:var(--accentSoftBg)}
.shift-toggle button.active{
  background:var(--accent);
  color:var(--accentText);
  box-shadow:0 8px 18px rgba(0,0,0,.10);
}
.shift-toggle button:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
.schedule-filter-dropdown{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}
.schedule-filter-trigger{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid var(--border);
  background:var(--surface2);
  color:var(--text);
  font-weight:800;
  line-height:1;
  height:37px;
  padding:0 38px 0 14px;
  border-radius:12px;
  cursor:pointer;
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  white-space:nowrap;
  box-shadow:none;
}
.schedule-filter-trigger::after{
  content:"▾";
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  font-size:11px;
  opacity:.72;
  transition:transform .15s ease;
}
.schedule-filter-dropdown.open .schedule-filter-trigger::after{
  transform:translateY(-50%) rotate(180deg);
}
.schedule-filter-dropdown.has-active .schedule-filter-trigger{
  background:var(--accentSoftBg);
  border-color:var(--accentSoftBorder);
}
.schedule-filter-menu{
  position:fixed;
  top:0;
  left:0;
  z-index:10020;
  width:min(360px, calc(100vw - 24px));
  max-width:calc(100vw - 24px);
  padding:12px;
  border-radius:16px;
  border:1px solid var(--border);
  background:var(--card);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.schedule-filter-actions{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
  margin-bottom:10px;
}
.schedule-filter-actions .btn{
  width:100%;
}
.schedule-interval-list{
  display:grid;
  grid-template-columns:1fr;
  gap:8px;
  max-height:min(46vh, 280px);
  overflow:auto;
  padding-right:2px;
}
.schedule-check{
  display:flex;
  align-items:flex-start;
  gap:10px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface2);
  cursor:pointer;
  min-width:0;
}
.schedule-check input{margin:2px 0 0;flex:0 0 auto}
.schedule-check__text{display:flex;flex-direction:column;min-width:0}
.schedule-check__title{font-weight:800;line-height:1.2;word-break:break-word}
.schedule-check__meta{font-size:12px;line-height:1.25;color:var(--muted)}
.btn-chip{border-radius:999px}
.btn-chip.active{
  background:var(--accentSoftBg);
  border-color:var(--accentSoftBorder);
  color:var(--text);
}
@media (max-width:560px){
  .schedule-filter-trigger{
    min-height:37px;
    padding:0 36px 0 14px;
  }
  .schedule-filter-menu{
    width:min(340px, calc(100vw - 20px));
    max-width:calc(100vw - 20px);
    padding:10px;
  }
}
@media (max-width:360px){
  .schedule-filter-actions{
    grid-template-columns:1fr;
  }
}
@media (max-width:420px){
  .shift-toggle{padding:3px}
  .shift-toggle button{padding:9px 10px;font-size:12px}
}



/* Segmented control (generic, e.g. reports mode) */
.seg-toggle{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:4px;
  border-radius:999px;
  border:1px solid var(--border);
  background:var(--surface2);
  -webkit-tap-highlight-color:transparent;
}
.seg-toggle button{
  appearance:none;
  border:0;
  background:transparent;
  color:var(--muted);
  font-weight:800;
  font-size:12px;
  line-height:1;
  padding:9px 11px;
  border-radius:999px;
  cursor:pointer;
  transition:background .15s ease, color .15s ease, transform .12s ease;
  user-select:none;
}
.seg-toggle button:active{transform:scale(.99)}
.seg-toggle button:hover{background:var(--accentSoftBg)}
.seg-toggle button.active{
  background:var(--accent);
  color:var(--accentText);
  box-shadow:0 8px 18px rgba(0,0,0,.10);
}
.seg-toggle button:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
@media (max-width:420px){
  .seg-toggle{padding:3px}
  .seg-toggle button{padding:8px 10px;font-size:12px}
}

.toggle{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:var(--surface2)}
.toggle__label{display:flex;flex-direction:column;gap:2px}
.toggle__title{font-weight:600}
.toggle__desc{font-size:12px;color:var(--muted)}

.switch{position:relative;display:inline-block;width:46px;height:28px;flex:0 0 auto}
.switch input{opacity:0;width:0;height:0}
.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background:var(--surface2);transition:.2s;border-radius:999px;border:1px solid var(--border)}
.switch .slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;top:3px;background:var(--text);border-radius:50%;transition:.2s}
.switch input:checked + .slider{background:rgba(52,199,89,.35)}
.switch input:checked + .slider:before{transform:translateX(18px)}
.switch input:disabled + .slider{opacity:.45;cursor:not-allowed}

/* Permission rows (reuse switch) */
.perm-tools{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-bottom:10px}
.perm-group-title{display:flex;align-items:center;justify-content:space-between;gap:10px}
.perm-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:12px;margin:8px 0;background:var(--surface2)}
.perm-text{min-width:0}
.perm-title{font-weight:800}
.perm-desc{opacity:.75;font-size:12px;margin-top:2px}
.perm-row.is-disabled{opacity:.55}

/* Disable switch animation during bulk on/off in positions modal */
.modal.bulk .switch .slider{transition:none !important;}
.modal.bulk .switch .slider:before{transition:none !important;}


/* Day panel (graph) */
.daypanel{margin-top:12px}
.daypanel-card{overflow:hidden}
.daypanel__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.daypanel__title{min-width:0}
.daypanel__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.daypanel__hint{margin-top:10px;font-size:12px}
.daypanel__empty{padding:12px 0}

/* Timeline graph */
.timeline{margin-top:12px;overflow-x:auto;padding-bottom:2px}
.timeline__axis{min-width:520px;display:grid;grid-template-columns:repeat(5,1fr);font-size:11px;color:var(--muted);font-weight:800}
.timeline__axis div:last-child{text-align:right}
.timeline__rows{min-width:520px;display:flex;flex-direction:column;gap:10px;margin-top:8px}
.timeline__row{display:grid;grid-template-columns:78px 1fr auto;gap:10px;align-items:center}
.timeline__time{font-family:var(--mono);font-size:12px;color:var(--muted)}
.timeline__track{position:relative;height:16px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);overflow:hidden}
.timeline__seg{position:absolute;left:var(--left);width:var(--w);top:0;bottom:0;border-radius:999px;background:rgba(var(--line-rgb), .35);box-shadow: inset 3px 0 0 rgb(var(--line-rgb))}
.timeline__meta{font-size:12px;color:var(--muted);font-weight:800;white-space:nowrap}
@media (max-width:520px){
  .timeline__axis{min-width:420px}
  .timeline__rows{min-width:420px}
  .timeline__row{grid-template-columns:68px 1fr auto}
  .timeline__meta{font-size:11px}
}

/* Modal as bottom sheet on mobile (Telegram WebView friendly) */
.modal__panel{padding-bottom:calc(14px + env(safe-area-inset-bottom))}
@media (max-width:560px){
  .modal__panel{
    left:0;
    right:0;
    top:auto;
    bottom:0;
    transform:none;
    width:100vw;
    max-height:min(92vh, 860px);
    border-radius:18px 18px 0 0;
  }
}

/* Stack helper */
.stack{display:grid;gap:12px}

/* Shift cards (day modal) */
.shiftcard{padding:14px}
.shiftcard__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.shiftcard__title{min-width:0}
.shiftcard__line1{display:flex;align-items:center;gap:8px;min-width:0}
.shiftcard__line1 b{font-weight:900}
.shiftcard__meta{margin-top:4px;font-size:12px}
.shiftcard__editor{margin-top:10px}

/* Comments */
.comments{margin-top:12px}
.comments__head{display:flex;justify-content:space-between;align-items:center;gap:10px}
.commentlist{margin-top:8px;display:grid;gap:8px}
.comment{
  border:1px solid var(--border);
  border-radius:14px;
  background:var(--surface2);
  padding:10px 12px;
}
.comment__head{display:flex;gap:8px;align-items:baseline;justify-content:space-between}
.comment__author{font-weight:900;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.comment__when{font-size:12px;color:var(--muted);white-space:nowrap}
.comment__text{margin-top:6px;font-size:13px;line-height:1.35;white-space:pre-wrap;word-break:break-word}

.commentform{margin-top:10px;display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.commentform__input{flex:1 1 260px;min-width:220px;min-height:84px}
.commentform__send{flex:0 0 auto}
@media (max-width:520px){
  .commentform{gap:8px}
  .commentform__input{min-width:0;flex:1 1 100%}
  .commentform__send{width:100%}
}

/* Reports: month summary + chart */
.monthsum{margin-top:12px}
.kpi{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:12px}
.kpi__item{border:1px solid var(--border);border-radius:14px;background:var(--surface2);padding:12px}
.kpi__label{font-size:12px;color:var(--muted)}
.kpi__value{margin-top:6px;font-weight:950;font-size:18px;letter-spacing:-.01em}
.kpi__sub{margin-top:2px;font-size:12px;color:var(--muted)}
@media (max-width:900px){.kpi{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:420px){.kpi{grid-template-columns:1fr}}


.progress{margin-top:12px;border:1px solid var(--border);border-radius:999px;background:var(--surface2);height:12px;overflow:hidden}
.progress__bar{height:100%;background:var(--accent);width:0;transition:width .18s ease}

.barchart{margin-top:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
.barchart__bars{min-width:540px;display:flex;gap:6px;align-items:flex-end;border:1px solid var(--border);border-radius:14px;background:var(--surface2);padding:10px}
.bar{appearance:none;border:0;background:transparent;padding:0;cursor:pointer;display:flex;flex-direction:column;gap:6px;align-items:center;min-width:10px}
.bar__col{width:10px;border-radius:999px;border:1px solid var(--border);background:var(--accentA12);height:calc(10px + (var(--h,0) * 92px));transition:transform .12s ease, filter .12s ease, background .12s ease}
:root[data-theme="dark"] .bar__col{background:rgba(60,120,200,.22)}
@media (prefers-color-scheme: dark){:root:not([data-theme="light"]) .bar__col{background:rgba(60,120,200,.22)}}
.bar.has .bar__col{background:var(--accentA18);border-color:var(--accentSoftBorder);box-shadow:inset 0 -10px 0 var(--barInset)}
:root[data-theme="dark"] .bar.has .bar__col{background:rgba(60,120,200,.28);box-shadow:inset 0 -10px 0 rgba(0,0,0,.18)}
@media (prefers-color-scheme: dark){:root:not([data-theme="light"]) .bar.has .bar__col{background:rgba(60,120,200,.28);box-shadow:inset 0 -10px 0 rgba(0,0,0,.18)}}
.bar:active .bar__col{transform:translateY(1px)}
.bar__label{font-size:11px;color:var(--muted);font-weight:800}
.bar.is-selected .bar__col{outline:2px solid var(--accent);outline-offset:2px}


/* Reports chart: fill/compliance mode */
.barchart.is-fillmode .bar__col{background:transparent;border-color:var(--border)}
.barchart.is-fillmode .bar.has .bar__col{background:var(--accentSoftBorder);border-color:var(--accent);box-shadow:none}
.barchart.is-fillmode .bar__label{opacity:.85}

.paybar{margin-top:10px;border:1px solid var(--border);border-radius:999px;background:var(--surface2);height:14px;overflow:hidden;display:flex}
.paybar__seg{height:100%}
.paybar__seg.cash{background:var(--accentA45)}
.paybar__seg.cashless{background:var(--accentA22)}
  :root:not([data-theme="light"]) .paybar__seg.cashless{background:rgba(60,120,200,.28)}


/* Empty / Error / Loading states */
.state{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);padding:16px;box-shadow:var(--shadow-sm)}
.state__title{font-weight:900;font-size:var(--fs-3);line-height:var(--lh-2)}
.state__text{margin-top:6px;color:var(--textSoft);font-size:var(--fs-2);line-height:var(--lh-3)}
.state__actions{margin-top:12px;display:flex;gap:10px;flex-wrap:wrap}



/* ------------------------------------------------------------
   Utilities (Sprint 2)
------------------------------------------------------------ */
.hidden{display:none !important}
.block{display:block}
.minw-0{min-width:0}
.w-100{width:100%}
.maxw-160{max-width:160px}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.mb-6{margin-bottom:6px}
.mb-8{margin-bottom:8px}
.mb-10{margin-bottom:10px}
.mb-12{margin-bottom:12px}
.pt-10{padding-top:10px}
.gap-8{gap:8px}
.gap-10{gap:10px}
.jc-between{justify-content:space-between}
.jc-end{justify-content:flex-end}
.jc-center{justify-content:center}
.ai-center{align-items:center}
.ai-start{align-items:flex-start}
.ai-end{align-items:flex-end}
.row--between{justify-content:space-between}
.row--end{justify-content:flex-end}
.row--center{justify-content:center}
.row--nowrap{flex-wrap:nowrap}
.divider-top{border-top:1px solid var(--border)}
.link-plain{color:inherit;text-decoration:none}
.no-underline{text-decoration:none}

/* Wider modal panel (e.g., photo viewer) */
.modal__panel--wide{max-width:720px}

/* ------------------------------------------------------------
   Legend (interval colors)
------------------------------------------------------------ */
.legend{display:flex;flex-direction:column;gap:10px;margin-top:10px;}
.legend__row{display:flex;align-items:center;gap:10px;min-width:0;padding:10px;border:1px solid var(--border);border-radius:14px;background:var(--card)}
.legend__swatch{width:14px;height:14px;border-radius:999px;flex:0 0 14px;box-shadow:0 0 0 2px rgba(0,0,0,0.02)}
.legend__text{min-width:0}
.legend__title{font-weight:900}
.legend__sub{margin-top:2px;color:var(--textSoft);font-size:var(--fs-2);line-height:var(--lh-3)}

/* ------------------------------------------------------------
   Simple bar chart (salary/month)
------------------------------------------------------------ */
.chart{margin-top:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);padding:10px;overflow:auto}
.chart__bars{display:flex;align-items:flex-end;gap:8px;min-height:110px}
.bar{appearance:none;border:0;background:transparent;padding:0;cursor:pointer;flex:0 0 10px;display:flex;flex-direction:column;align-items:center;gap:6px}
.bar__track{width:10px;height:96px;border-radius:999px;background:var(--accentA10);border:1px solid var(--border);display:flex;align-items:flex-end;overflow:hidden}
.bar__fill{width:100%;height:var(--h,0%);background:var(--barColor,var(--accent));border-radius:999px}
.bar__label{font-size:10px;color:var(--muted);line-height:1}
.bar:focus{outline:none}
.bar:focus .bar__track{box-shadow:var(--focusRing)}

.month-controls{
  font-size: 25px;
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
  flex:1 1 auto;
  justify-content:center;
}

/* Salary day rows */
.dayrow__right{display:flex;align-items:center;gap:10px}
.day-salary--muted{opacity:.45}
.section{border-bottom:1px solid var(--border);padding:10px 0}
.section:last-child{border-bottom:0}

/* Photo viewer */
.photoStage{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#000}
.photoStage__img{display:block;width:100%;height:auto;max-height:70vh;object-fit:contain;margin:0 auto}

/* width utilities */
.minw-240{min-width:240px}
.minw-380{min-width:380px}
.maxw-45{max-width:45px !important}


/* ===== Month calendar: ALL mode dots ===== */
#calGrid:not(.is-week) .cal-cell{ padding-right:6px; }

#calGrid:not(.is-week) .cal-badges.cal-badges--dots{
  flex-direction:row;
  flex-wrap:wrap;           /* allow 2nd row */
  gap:3px;
  row-gap:3px;
  margin-top:6px;
  align-items:center;
  align-content:flex-start;
  padding-right:2px;
  max-width:100%;
}

#calGrid:not(.is-week) .cal-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  box-sizing:border-box;
  border:2px solid var(--dot, var(--muted));
  background:transparent;
  flex:0 0 auto;
  display:block;
}

#calGrid:not(.is-week) .cal-dot.is-filled{
  background:var(--dot, var(--muted));
}

#calGrid:not(.is-week) .cal-dot.is-more{
  border-color: var(--border);
  background: var(--surface2);
  color: var(--muted);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:6.5px;
  font-weight:900;
  letter-spacing:-0.2px;
}


/* ===== PATCH: week header readability + month dots wrap v3 ===== */
/* Week header: consistent readable color across Telegram themes */
#calGrid.is-week .cal-weektop .cal-weekname,
#calGrid.is-week .cal-weektop .cal-weekdate,
#calGrid.is-week .cal-weektop .cal-daymeta{
  color: var(--text);
}
#calGrid.is-week .cal-weektop .cal-weekname{ opacity:.72; }
#calGrid.is-week .cal-weektop .cal-daymeta{ opacity:.72; }

/* Dots: allow second row */
#calGrid:not(.is-week) .cal-badges.cal-badges--dots{
  flex-wrap:wrap;
  row-gap:3px;
}

/* ===== Shift report (B2): dynamic close form ===== */
.badge--draft{border-color:rgba(255,204,0,.42);background:rgba(255,204,0,.16)}
.badge--closed{border-color:rgba(52,199,89,.34);background:rgba(52,199,89,.12)}

.cal-cell--draft{background:rgba(255,204,0,.12);border-color:rgba(255,204,0,.24);box-shadow:0 0 0 1px rgba(255,204,0,.14) inset}
.cal-cell--closed{background:rgba(52,199,89,.12);border-color:rgba(52,199,89,.24);box-shadow:0 0 0 1px rgba(52,199,89,.18) inset}
.cal-cell--report-overdue{background:rgba(255,59,48,.11);border-color:rgba(255,59,48,.22);box-shadow:0 0 0 1px rgba(255,59,48,.14) inset}

.rep-topmeta{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.rep-topmeta__left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.rep-topmeta__right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}

.rep-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;line-height:1;padding:5px 10px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);font-weight:900;letter-spacing:.06em}
.rep-badge--draft{opacity:.85}
.rep-badge--closed{border-color:var(--accentSoftBorder);background:var(--accentSoftBg)}

.rep-sec{border:1px solid var(--border);background:var(--surface2);border-radius:16px;padding:12px;margin-top:12px}
.rep-sec__head{margin-bottom:10px}
.rep-sec__body{min-width:0}

.rep-grid{display:grid;grid-template-columns:repeat(2, minmax(0, 1fr));gap:10px}
.rep-grid--single{grid-template-columns:1fr}
@media (max-width: 520px){
  .rep-grid{grid-template-columns:1fr}
}

.rep-field{display:block;min-width:0}
.rep-field__label{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:6px;font-size:12px;color:var(--muted)}
.rep-field input{width:100%}

.rep-totals{display:grid;grid-template-columns:repeat(3, minmax(0, 1fr));gap:10px}
@media (max-width: 520px){
  .rep-totals{grid-template-columns:1fr}
}
.rep-total{border:1px solid var(--border);background:var(--card);border-radius:14px;padding:10px;min-width:0}
.rep-total__v{font-weight:950;font-size:16px;margin-top:4px}
.rep-total--discr.is-bad{border-color:var(--dangerBorder);background:rgba(220,60,60,.06)}
.rep-total--discr.is-ok{opacity:.92}

.rep-comment{width:100%;min-height:92px;resize:none}
.rep-comment.is-required{border-color:var(--dangerBorder)!important;box-shadow:0 0 0 2px rgba(220,60,60,.12) inset}

.rep-divider{height:1px;background:var(--border);margin:14px 0}

.audit-item{border:1px solid var(--border);background:var(--card);border-radius:14px;padding:8px 10px;margin-top:10px}
.audit-item summary{cursor:pointer;display:flex;justify-content:space-between;gap:10px;align-items:center;list-style:none}
.audit-item summary::-webkit-details-marker{display:none}
.audit-when{font-weight:900}
.audit-body{margin-top:10px}
.audit-list{margin:0;padding-left:18px}
.audit-list li{margin:4px 0}


/* -------- Revenue (Turnover) period toolbar -------- */
.h2{font-size:26px;font-weight:800;letter-spacing:-0.02em}
@media (max-width:900px){.h2{font-size:22px}}

.revenue-toolbar{
  display:grid;
  gap:14px;
  padding:14px;
}
.revenue-toolbar__section{
  display:grid;
  gap:8px;
  min-width:0;
}
.revenue-toolbar__section--bottom{
  gap:12px;
}
.revenue-toolbar__label{
  color:var(--muted);
  font-size:13px;
  font-weight:800;
}
.revenue-toolbar__actions{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
}
.revenue-toolbar__caption{
  min-width:0;
}
.seg{
  display:flex;
  gap:6px;
  padding:4px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,0.10);
  background: rgba(0,0,0,0.15);
  min-width:0;
}
.seg button{
  flex:1 1 0;
  min-width:0;
  border:0;
  background:transparent;
  color:inherit;
  padding:10px 12px;
  border-radius:999px;
  cursor:pointer;
  opacity:0.85;
  white-space:nowrap;
}
.seg button.active{
  background: rgba(255,255,255,0.10);
  opacity:1;
}
.pickers{display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-width:0}
.pickers input{width:auto;min-width:160px;max-width:100%}
.pickers--revenue{width:100%}
.range-pick{display:flex;gap:8px;align-items:center;flex-wrap:wrap;width:100%}
.range-pick input{flex:1 1 180px}

@media (max-width:760px){
  .seg--period{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-radius:18px}
  .seg--mode{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));border-radius:18px}
  .seg button{white-space:normal;line-height:1.15;text-align:center}
  .pickers--revenue > input,
  .pickers--revenue > .range-pick{width:100%}
  .pickers--revenue input{min-width:0;width:100%}
  .revenue-toolbar__actions{align-items:stretch}
  .revenue-toolbar__actions .btn{width:100%}
}



/* -------- Finance summary / expenses -------- */
.finance-stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:12px;
}
.finance-stat{display:grid;gap:8px;min-width:0}
.finance-stat__label{color:var(--muted);font-size:13px;font-weight:800}
.finance-stat__value{font-size:24px;font-weight:900;letter-spacing:-0.02em;min-width:0;word-break:break-word}
.finance-filters{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.expense-list{display:grid;gap:10px}
.expense-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;padding:14px;border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,0.02)}
.expense-row__title{font-weight:800}
.expense-row__side{display:grid;justify-items:end;align-content:start;min-width:120px}
.expense-row__amount{font-size:20px;font-weight:900;white-space:nowrap}
.expense-row__allocations{display:flex;gap:6px;flex-wrap:wrap}
.finance-form{display:grid;gap:10px}
.finance-form label:not(.chk):not(.checkline):not(.row){display:grid;gap:6px;font-size:13px;color:var(--muted);font-weight:700}
.finance-form label.chk,
.finance-form label.checkline,
.finance-form label.row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;max-width:100%}
.finance-form > label.chk,
.finance-form > label.checkline,
.finance-form > label.row,
.finance-form > .chk,
.finance-form > .checkline{justify-self:start;width:auto}
.finance-form label.chk{font-size:13px;color:var(--text);font-weight:700}
.finance-form label.row{font-size:13px;color:var(--muted);font-weight:700}
.finance-form input,.finance-form select,.finance-form textarea{width:100%}
.form-section{display:grid;gap:10px;padding:14px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.03)}
.form-section__head{display:grid;gap:4px}
.form-section__title{font-size:13px;font-weight:900;letter-spacing:.02em}
.form-section__subtitle{font-size:12px;color:var(--muted);line-height:1.4}
.form-section__grid{display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}
.form-section__grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.form-inline-note{font-size:12px;color:var(--muted);line-height:1.45}
.form-note{display:grid;gap:6px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:var(--surface2);font-size:13px;color:var(--muted)}
.form-note--warn{border-color:var(--accentSoftBorder);background:rgba(255,255,255,0.03)}
.form-note--info{border-color:rgba(137,180,255,.25);background:rgba(137,180,255,.08)}
.pay-config-summary{display:grid;gap:6px;padding:12px;border-radius:14px;border:1px dashed var(--accentSoftBorder);background:var(--accentSoftBg)}
.pay-config-summary__eyebrow{font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.pay-config-summary__title{font-size:14px;font-weight:900;line-height:1.35}
.pay-config-summary__meta{font-size:12px;color:var(--muted);line-height:1.45}
.btn.ghost{background:transparent}
.btn.small{padding:8px 10px;font-size:13px}
@media (max-width:900px){
  .finance-stats{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:900px){
  .finance-stats-1{grid-template-columns:repeat(1,minmax(0,1fr))}
}
@media (max-width:760px){
  .finance-filters{grid-template-columns:1fr}
  .expense-row{grid-template-columns:1fr}
  .expense-row__side{justify-items:start;min-width:0}
  .finance-stat__value{font-size:15px}
}


@media (max-width:760px){
  .form-section__grid,
  .form-section__grid--3{grid-template-columns:1fr;}
}

.auth-shell{padding-top:8px}
.auth-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.auth-label{display:block;font-size:13px;color:var(--muted)}
.auth-divider{height:1px;background:var(--border)}
@media (max-width:900px){.auth-grid{grid-template-columns:1fr}}


.auth-inline-links{gap:8px;justify-content:flex-start}
.auth-mode-switch{gap:8px;align-items:center}
.auth-mode-switch .btn{min-width:0}
.stack{display:flex;flex-direction:column;gap:10px}
.mt-4{margin-top:4px}
.mt-6{margin-top:6px}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}

@media (max-width:760px){
  .topbar{align-items:flex-start;gap:10px;margin-bottom:14px; padding: 0 4px;}
  .logo{width:36px;height:36px}
}


.telegram-widget-host{display:flex;align-items:center;justify-content:flex-start;min-height:50px}
.telegram-widget-host iframe{max-width:100%}

/* -------- Payroll -------- */
.payroll-breakdown{border-top:1px dashed var(--border); padding-top:10px}
.payroll-breakdown summary{cursor:pointer; color:var(--muted); font-weight:800}
.payroll-breakdown__body{display:grid; gap:8px}
.payroll-breakdown__row{display:grid; grid-template-columns:minmax(0,1fr) auto; gap:12px; padding:10px 12px; border:1px solid var(--border); border-radius:14px; background:rgba(255,255,255,0.02)}
@media (max-width:760px){
  .payroll-breakdown__row{grid-template-columns:1fr}
}

/* payroll on staff salary */
.payroll-breakdown{border-top:1px dashed var(--border); padding-top:10px}
.payroll-breakdown__body{display:grid; gap:8px}
.payroll-breakdown__row{display:grid; grid-template-columns:minmax(0,1fr) auto; gap:12px; padding:10px 12px; border:1px solid var(--border); border-radius:14px; background:rgba(255,255,255,0.02)}
@media (max-width:640px){
  .payroll-breakdown__row{grid-template-columns:1fr}
}

.modal__panel--wide{max-width:min(1100px,calc(100vw - 24px));width:min(1100px,calc(100vw - 24px));}
.export-modal-panel{
  position:relative;
  left:auto;
  top:auto;
  transform:none;
  width:min(1100px,calc(100vw - 24px));
  max-width:min(1100px,calc(100vw - 24px));
  max-height:calc(100vh - 24px);
  margin:12px auto;
  padding:18px;
}
#exportModal{align-items:center;justify-content:center;padding:0 12px;}
#exportModal.open{display:flex;}
.export-modal-head{align-items:flex-start;}
.export-modal-copy{display:grid;gap:6px;}
.export-modal-copy .modal__subtitle{color:var(--muted);line-height:1.35;}
.export-modal-body{display:grid;gap:14px;padding-top:14px;}
.export-status{min-height:0;margin:0;font-size:12px;line-height:1.35;}
.export-status:empty{display:none;}
.export-preview-wrap{display:flex;justify-content:center;align-items:center;min-height:220px;padding:14px;border:1px solid var(--border);border-radius:20px;background:rgba(255,255,255,.04);overflow:auto;}
.export-preview-image{display:block;max-width:100%;max-height:68vh;border-radius:18px;border:1px solid var(--border);background:#fff;box-shadow:0 16px 40px rgba(0,0,0,.16);}
.export-preview-image.hidden{display:none;}
.export-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;}
.export-actions .btn{display:flex;align-items:center;justify-content:center;min-height:48px;}
@media (max-width:900px){
  .export-actions{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media (max-width:560px){
  #exportModal{padding:0 10px;}
  .export-modal-panel{width:min(1100px,calc(100vw - 20px));max-width:min(1100px,calc(100vw - 20px));margin:10px auto;padding:14px;max-height:calc(100vh - 20px);}
  .export-preview-wrap{padding:10px;min-height:160px;}
  .export-preview-image{max-height:52vh;}
  .export-actions{grid-template-columns:1fr;}
}

.notif-modal-card{display:grid;gap:10px;}
.notif-state-banner{padding:12px 14px;border-radius:14px;border:1px solid var(--border);font-size:13px;line-height:1.4;background:rgba(255,255,255,.04);}
.notif-state-banner--ok{border-color:var(--accentSoftBorder);background:var(--accentSoftBg);}
.notif-state-banner--warn{border-color:rgba(255,184,77,.35);background:rgba(255,184,77,.10);}
.notif-inline-state{min-height:18px;font-size:12px;line-height:1.35;}
.notif-fields{margin-top:8px;transition:opacity .2s ease;}
.notif-fields.is-dimmed{opacity:.55;}
.notif-badge{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:11px;font-weight:800;letter-spacing:.04em;background:var(--surface2);white-space:nowrap;}
.notif-badge--ok{border-color:var(--accentSoftBorder);background:var(--accentSoftBg);}
.notif-badge--err{border-color:rgba(255,107,107,.30);background:rgba(255,107,107,.12);}
.notif-badge--wait{border-color:rgba(255,184,77,.35);background:rgba(255,184,77,.12);}
.notif-history-card{display:grid;gap:8px;}
.notif-history-preview{padding:10px 12px;border-radius:12px;background:rgba(255,255,255,.04);font-size:13px;line-height:1.4;white-space:pre-wrap;word-break:break-word;}
.notif-history-error{padding:10px 12px;border-radius:12px;border:1px solid rgba(255,107,107,.25);background:rgba(255,107,107,.10);font-size:12px;line-height:1.4;white-space:pre-wrap;word-break:break-word;}
@media (max-width:640px){
  .notif-state-banner{padding:10px 12px;}
  .notif-badge{width:100%;justify-content:flex-start;}
}

@media (max-width:760px){
  .listrow{flex-direction:column;align-items:stretch;}
  .listrow__left{width:100%;} 
  .listrow .row--nowrap{width:100%;flex-wrap:wrap;gap:8px;}
  .listrow .row--nowrap > .btn,
  .listrow .row--nowrap > a.btn{flex:1 1 calc(50% - 8px);min-width:0;text-align:center;justify-content:center;}
}
@media (max-width:420px){
  .listrow .row--nowrap > .btn,
  .listrow .row--nowrap > a.btn{flex:1 1 100%;}
}


/* pay component simulator */
.pay-sim{display:grid;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:16px;background:rgba(255,255,255,.04);}
.pay-sim__title{font-size:13px;font-weight:800;}
.pay-sim__grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;}
.pay-sim__result{display:grid;gap:10px;padding:10px 12px;border-radius:14px;border:1px dashed var(--border);background:rgba(255,255,255,.03);line-height:1.45;}
.pay-sim__stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;}
.pay-sim__stat{display:grid;gap:4px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.03);}
.pay-sim__stat--accent{border-color:var(--accentSoftBorder);background:var(--accentSoftBg);}
.pay-sim__stat-label{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.pay-sim__stat-value{font-size:14px;font-weight:900;line-height:1.25;}
.pay-sim__note{font-size:12px;color:var(--muted);line-height:1.5;}
@media (max-width:760px){
  .pay-sim__grid,.pay-sim__stats{grid-template-columns:1fr;}
}

.payroll-breakdown__header{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;}
.payroll-breakdown__eyebrow{font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.payroll-breakdown__title{font-size:15px;font-weight:900;line-height:1.3;}
.payroll-breakdown__explain{font-size:12px;color:var(--muted);line-height:1.45;margin-top:4px;}
.payroll-breakdown__amount{font-size:16px;font-weight:900;white-space:nowrap;}
.payroll-breakdown__badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;}
.payroll-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);font-size:11px;font-weight:800;letter-spacing:.03em;background:var(--surface2);}
.payroll-chip--ok{border-color:var(--accentSoftBorder);background:var(--accentSoftBg);}
.payroll-chip--warn{border-color:rgba(255,184,77,.35);background:rgba(255,184,77,.12);}
.payroll-chip--muted{opacity:.92;}
.payroll-breakdown__kv{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:10px;}
.payroll-breakdown__kv-item{display:grid;gap:4px;padding:10px 12px;border:1px solid var(--border);border-radius:14px;background:rgba(255,255,255,.02);}
.payroll-breakdown__kv-label{font-size:11px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);}
.payroll-breakdown__kv-value{font-size:13px;font-weight:800;line-height:1.35;}
.payroll-breakdown__dayrows{display:grid;gap:8px;margin-top:10px;}
.payroll-breakdown__dayrow{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;border:1px dashed var(--border);background:rgba(255,255,255,.02);}
.payroll-breakdown__dayrow-main{min-width:0;}
.payroll-breakdown__dayrow-date{font-size:13px;font-weight:900;}
.payroll-breakdown__dayrow-meta{font-size:12px;color:var(--muted);line-height:1.4;margin-top:3px;}
.payroll-breakdown__dayrow-amount{font-size:13px;font-weight:900;white-space:nowrap;}
@media (max-width:760px){
  .payroll-breakdown__header,.payroll-breakdown__dayrow,.payroll-breakdown__kv{grid-template-columns:1fr;}
  .payroll-breakdown__amount,.payroll-breakdown__dayrow-amount{white-space:normal;}
}

.dept-plan-table{display:grid; gap:10px;}
.dept-plan-table__head,
.dept-plan-table__row{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:10px; align-items:start;}
.dept-plan-table__head{font-size:12px; color:var(--muted); padding:0 4px;}
.dept-plan-table__row{padding:12px; border:1px solid var(--border); border-radius:14px; background:var(--card);}
.dept-plan-table textarea{min-height:68px; resize:vertical;}
@media (max-width: 860px){
  .dept-plan-table__head{display:none;}
  .dept-plan-table__row{grid-template-columns:1fr;}
}


/* ===== UI refresh 2026-03 ===== */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:44px;
  transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,transform .16s ease,opacity .16s ease;
}
.btn:hover{border-color:var(--accentSoftBorder);box-shadow:0 0 0 1px var(--accentA12) inset}
.btn.primary{box-shadow:0 10px 24px var(--accentA18)}
.btn.ghost{background:transparent;border-color:var(--border);box-shadow:none}
.btn.subtle{background:transparent;border-color:var(--accentSoftBorder);color:var(--text);box-shadow:none}
.btn.subtle:hover,.btn.ghost:hover{background:var(--accentSoftBg)}
.btn.inline,.btn-inline{min-height:38px;padding:8px 12px;border-radius:999px;font-size:13px}
.btn.linklike{padding:8px 12px;border-radius:999px;font-size:13px}
.btn.block{width:100%}
.btn.small{min-height:36px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.btn-row--end{justify-content:flex-end}
.back-actions{display:flex;gap:8px;flex-wrap:wrap}

a.link{color:var(--accent);text-decoration:none;font-weight:800}
a.btn{color:var(--text);text-decoration:none}
a.btn.primary{color:var(--accentText)}

.modal__panel{padding:16px}
.modal__head{padding-bottom:12px;border-bottom:1px solid var(--border);margin-bottom:12px}
.modal__title{font-weight:900;font-size:18px;letter-spacing:-0.01em}
.modal__body{padding-bottom:2px}

.screen-hero{display:grid;gap:12px}
.screen-hero__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.screen-hero__toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.screen-hero__period{display:flex;gap:8px;align-items:center;flex-wrap:wrap;min-width:0}
.screen-hero__actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.finance-period-card{display:grid;gap:6px}
.finance-period-card__label{font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.finance-period-card__value{font-size:18px;font-weight:900;letter-spacing:-0.02em}
.finance-kpis{display:grid;gap:12px}
.finance-kpis--primary{grid-template-columns:repeat(3,minmax(0,1fr))}
.finance-kpis--secondary{grid-template-columns:repeat(5,minmax(0,1fr))}
.finance-kpis--ratios{grid-template-columns:repeat(3,minmax(0,1fr))}
.finance-kpis--compact{grid-template-columns:repeat(3,minmax(0,1fr))}
.finance-stat--hero{padding:18px}
.finance-stat--hero .finance-stat__value{font-size:30px}
.finance-stat__meta{font-size:12px;color:var(--muted);line-height:1.4}
.finance-shortcuts{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.finance-shortcuts .btn{width:100%}
.inline-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.inline-actions--wrap{display:grid;gap:8px}
.inline-note{font-size:12px;color:var(--muted);line-height:1.45}
.collapsible-card{border:1px solid var(--border);border-radius:18px;background:rgba(255,255,255,.02);overflow:hidden}
.collapsible-card > summary{list-style:none;cursor:pointer;padding:14px 16px;font-weight:900;display:flex;align-items:center;justify-content:space-between;gap:12px}
.collapsible-card > summary::-webkit-details-marker{display:none}
.collapsible-card > summary::after{content:'▾';font-size:14px;color:var(--muted);transition:transform .16s ease}
.collapsible-card[open] > summary::after{transform:rotate(180deg)}
.collapsible-card__body{padding:0 16px 16px}
.expense-hero-total{display:grid;gap:6px;min-width:min(280px,100%)}
.expense-hero-total__label{font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.expense-hero-total__value{font-size:30px;font-weight:900;letter-spacing:-0.02em;word-break:break-word}
.filters-wrap{display:grid;gap:10px}
.catalog-actions{display:flex;gap:8px;flex-wrap:wrap}
.help-copy{max-width:720px}
.state-card{display:grid;gap:8px;align-content:start}
.state-card__label{font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.state-card__value{font-size:16px;font-weight:800;line-height:1.4}
.row-link-actions{display:flex;gap:8px;flex-wrap:wrap}

@media (max-width:900px){
  .finance-kpis--secondary{grid-template-columns:repeat(2,minmax(0,1fr))}
  .finance-kpis--ratios,.finance-kpis--compact{grid-template-columns:repeat(2,minmax(0,1fr))}
  .finance-shortcuts{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .screen-hero__toolbar,.screen-hero__period,.screen-hero__actions{width:100%}
  .screen-hero__actions:not(.screen-hero__actions--adaptive) .btn,.screen-hero__period > input,.screen-hero__period > .range-pick{width:100%}
  .screen-hero__actions--adaptive{width:100%}
  .finance-kpis--primary,.finance-kpis--secondary,.finance-kpis--ratios,.finance-kpis--compact,.finance-shortcuts{grid-template-columns:1fr}
  .finance-stat--hero .finance-stat__value,.expense-hero-total__value{font-size:24px}
  .modal__panel{max-height:calc(100vh - 20px)}
}


.section-card{display:grid;gap:12px;align-content:flex-start;}
.section-card__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.section-card__title{display:grid;gap:6px}
.section-card__actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.action-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.action-grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.action-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.action-grid--adaptive{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.action-grid .btn{width:100%}
.action-grid--adaptive .btn{display:flex;align-items:center;justify-content:center;min-height:52px;text-align:center;white-space:normal;line-height:1.25}
.action-grid--mobile-2{grid-template-columns:repeat(auto-fit,minmax(min(150px,100%),1fr))}
.screen-hero__actions--adaptive{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(140px,100%),1fr));width:min(100%,420px)}
.screen-hero__actions--adaptive .btn{width:100%}
.section-split-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.hero-summary-card{display:grid;gap:8px;min-width:min(300px,100%)}
.hero-summary-card__eyebrow{font-size:12px;font-weight:900;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.hero-summary-card__value{font-size:28px;font-weight:900;letter-spacing:-0.02em;word-break:break-word}
.hero-summary-card__meta{font-size:13px;color:var(--muted);line-height:1.45}
.toolbar-meta-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
.compact-stat-grid{display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr))}
.section-stack{display:grid;gap:12px}
.section-stack > .itemcard{height:100%}
.text-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.text-actions .btn{min-height:40px}
.itemcard--soft{background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0)), var(--surface2)}
.itemcard--clear{background:transparent}
.form-radio-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.form-radio-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface2);font-weight:800;color:var(--text);cursor:pointer}
.form-radio-chip input{margin:0}
.screen-hero__meta-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}
.screen-hero__meta-grid .itemcard{height:100%}
.page-caption{font-size:13px;color:var(--muted);line-height:1.45;max-width:760px}
.table-like-list{display:grid;gap:8px}
.table-like-list > .row{padding:10px 0;border-bottom:1px solid var(--border)}
.table-like-list > .row:last-child{border-bottom:none}

@media (max-width:900px){
  .action-grid,.compact-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .toolbar-meta-grid,.screen-hero__meta-grid,.section-split-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .action-grid:not(.action-grid--mobile-2),.action-grid--3:not(.action-grid--mobile-2),.action-grid--2:not(.action-grid--mobile-2),.compact-stat-grid{grid-template-columns:1fr}
  .action-grid--adaptive{grid-template-columns:repeat(auto-fit,minmax(140px,1fr)) !important}
  .action-grid--mobile-2{grid-template-columns:repeat(auto-fit,minmax(min(140px,100%),1fr)) !important}
  .hero-summary-card__value{font-size:24px}
}
