:root{
  --font:"Golos Text",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-display:"Unbounded","Golos Text",sans-serif;

  /* dark surfaces (RestForm) */
  --paper:#0e0e0e;
  --card:#181818;
  --card-2:#222222;
  --ink:#f0ead8;
  --ink-soft:#8a8070;
  --line:#2e2e2e;
  --line-strong:#3a3a3a;
  --track:rgba(240,234,216,.1);

  /* accent (antique gold) */
  --brand:#c8a96e;
  --brand-bright:#e2c98a;
  --brand-ink:#0e0e0e;
  --brand-tint:rgba(200,169,110,.13);
  --brand-line:rgba(200,169,110,.42);

  /* roles */
  --cook:#e05a4a;
  --bar:#5ab8a0;
  --waiter:#cf875a;
  --dish:#7d92c4;

  /* semantic (RestForm) */
  --payout:#5ab87a;
  --payday:#e2c98a;
  --score-good:#5ab87a;
  --score-mid:#e0a84a;
  --score-bad:#e05a4a;
  --green:#5ab87a;
  --green-fill:#3a8f5d;
  --gold:#e0a84a;
  --gold-bg:rgba(224,168,74,.11);
  --teal:#5ab8a0;
  --weekend:#1a1815;

  --ok-bg:rgba(90,184,122,.11);
  --ok-line:rgba(90,184,122,.4);
  --danger:#e05a4a;
  --danger-bg:rgba(224,90,74,.11);
  --danger-line:rgba(224,90,74,.4);

  /* service icon tints (dark-palette) */
  --teal-tint:rgba(90,184,160,.13);
  --gold-tint:rgba(224,168,74,.13);
  --green-tint:rgba(90,184,122,.13);
  --ink-tint:rgba(240,234,216,.08);

  /* radius scale */
  --r-sm:8px;
  --r-md:12px;
  --r-lg:16px;
  --r-pill:999px;

  --shadow:0 1px 2px rgba(0,0,0,.5),0 8px 24px rgba(0,0,0,.4);

  color-scheme:dark;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;min-height:100%;background:var(--paper);color:var(--ink);font-family:var(--font);font-feature-settings:"tnum" 1;touch-action:manipulation;-webkit-text-size-adjust:100%}
button,a,input,select,textarea{font:inherit;touch-action:manipulation}
input,select,textarea{accent-color:var(--brand)}
input::placeholder,textarea::placeholder{color:var(--ink-soft);opacity:.6}
input[type=number]{-moz-appearance:textfield}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
select{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:42px;border:1px solid var(--line-strong);background-color:var(--card);color:var(--ink);border-radius:10px;padding:0 34px 0 12px;font:inherit;font-size:14px;font-weight:500;cursor:pointer;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8070' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
select:focus{outline:none;border-color:var(--brand)}
button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible,summary:focus-visible{outline:2px solid var(--brand-line);outline-offset:2px}
a{color:inherit;text-decoration:none}
.app-shell{min-height:100vh;display:block;padding:0;background:var(--paper)}
.phone,.phone.wide,.phone.schedule-phone,.admin-phone,.shift-close-phone,.payroll-phone{width:100%;max-width:none;min-height:100vh;background:var(--paper);border:0;border-radius:0;box-shadow:none;overflow:visible}
.screen{min-height:100vh;padding:22px 16px 28px}
.top{display:flex;align-items:center;gap:10px;margin:2px 2px 18px}
.mark{width:9px;height:28px;border-radius:3px;background:var(--brand);flex:none}
.brand-title{font-family:var(--font-display);font-size:20px;line-height:1;font-weight:700;letter-spacing:.01em;margin:0}
.top-meta{margin-left:auto;text-align:right;color:var(--ink-soft);font-size:12px;font-weight:700}
.pin-wrap{display:flex;flex-direction:column;align-items:center;padding-top:36px}
.logo{width:92px;height:92px;border-radius:20px;display:flex;align-items:center;justify-content:center}
.logo img{width:100%;height:100%;object-fit:contain;display:block}
.logo span{font-family:var(--font-display);color:var(--brand-ink);font-size:40px;font-weight:700;line-height:1}
.pin-title{font-family:var(--font-display);font-size:17px;font-weight:700;letter-spacing:.04em;color:var(--brand-bright);margin:16px 0 4px}
.pin-sub{font-size:13px;color:var(--ink-soft);margin-top:18px;margin-bottom:24px}
.dots{display:flex;gap:14px;margin-bottom:30px}
.dots i{width:14px;height:14px;border-radius:50%;border:2px solid var(--line-strong);background:transparent}
.dots i.f{background:var(--brand);border-color:var(--brand)}
.keypad{display:grid;grid-template-columns:repeat(3,72px);gap:14px}
.key{height:64px;border-radius:var(--r-lg);border:1px solid var(--line);background:var(--card);font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--ink);cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center}
.key:active{transform:scale(.96)}
.key.blank{border:none;background:transparent;box-shadow:none;pointer-events:none}
.key.fn{font-size:14px;color:var(--ink-soft);font-weight:600}
.error{min-height:20px;margin-top:18px;color:var(--danger);font-size:13px;font-weight:700;text-align:center}
.greet{margin:4px 2px 14px}
.hi{font-family:var(--font-display);font-size:21px;font-weight:700;letter-spacing:.01em}
.role{display:inline-block;margin-top:7px;font-size:12px;font-weight:700;color:var(--brand-ink);background:var(--brand);border-radius:var(--r-pill);padding:4px 11px}
.sec,.section-title{font-family:var(--font-display);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--brand-bright);margin:22px 4px 10px}
.nav{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.navcard{background:var(--card);border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:var(--r-lg);padding:14px 13px;box-shadow:var(--shadow);cursor:pointer;color:var(--ink);min-height:116px;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:11px;text-align:left}
.navcard:active{transform:scale(.98)}
.navcard .icon{width:34px;height:34px;border-radius:var(--r-sm);background:var(--brand-tint);display:flex;align-items:center;justify-content:center;color:var(--brand-bright)}
.navcard svg{width:19px;height:19px;stroke-width:2.1}
.navcard .t{display:block;font-weight:600;font-size:15px}
.navcard .d{display:block;font-size:12px;color:var(--ink-soft);line-height:1.35;margin-top:4px;font-weight:400}
.service-page{min-height:520px}
.backrow{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.iconbtn{width:38px;height:38px;border-radius:var(--r-md);border:1px solid var(--line-strong);background:var(--card);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow);flex:none}
.iconbtn.small{width:32px;height:32px;border-radius:var(--r-sm)}
.page-title{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:.01em;margin:0}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:15px;box-shadow:var(--shadow)}
.panel + .panel{margin-top:10px}
.row{display:flex;align-items:center;gap:12px}
.grow{flex:1;min-width:0}
.row-title{font-size:15px;font-weight:600}
.row-sub{font-size:12px;color:var(--ink-soft);margin-top:3px}
.status{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--green);border:1px solid var(--ok-line);background:var(--ok-bg);border-radius:var(--r-pill);padding:4px 9px;white-space:nowrap}
.ghost{border:1px solid var(--line-strong);background:transparent;border-radius:var(--r-md);padding:10px 12px;font-weight:600;color:var(--ink);cursor:pointer}
.ghost.mini{padding:6px 9px;font-size:12px;border-radius:var(--r-sm)}
.brand-action{border-color:var(--brand);color:var(--brand-ink);background:var(--brand);font-family:var(--font-display);font-weight:700}
.danger-action{color:var(--danger);border-color:var(--danger-line)}
.logout{margin-left:auto}
.loader{padding:70px 18px;text-align:center;color:var(--ink-soft);font-size:13px;font-weight:700}
.loader.compact{padding:20px 8px}
.file-btn{position:relative;overflow:hidden}
.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}
.import-panel{margin:16px 4px 0;color:var(--ink-soft);font-size:12px}
.import-panel summary{display:inline-flex;align-items:center;gap:7px;cursor:pointer;font-weight:600;list-style:none}
.import-panel summary::-webkit-details-marker{display:none}
.import-panel .mini-icon{width:20px;height:20px;background:rgba(255,255,255,.05);color:var(--ink-soft)}
.import-body{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:9px;padding:10px 0 0;border-top:1px solid var(--line)}
.import-result{margin-top:9px;font-size:12px;color:var(--ink-soft);font-weight:700}
.shift-close-phone{max-width:760px}
.shift-close-screen{padding:18px 14px 28px}
.shift-close-form{max-width:720px;margin:0 auto}
.shift-close-form .field{margin-bottom:10px}
.shift-close-form .two{margin-bottom:10px}
.shift-close-form .two .field{margin-bottom:0}
.shift-close-form .sec{margin-top:26px}
.shift-close-form .sec:first-of-type{margin-top:14px}
.shift-close-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin:0 2px 4px}
.shift-head-main{flex:1;min-width:0}
.shift-date-nav{display:flex;align-items:center;gap:12px;margin-top:10px}
.shift-date-label{flex:1;text-align:center;line-height:1.15}
.shift-date-cap{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--ink-soft);font-weight:600}
.shift-date-day{display:block;font-size:15px;font-weight:600;color:var(--ink)}
.iconbtn.small:disabled{opacity:.35;cursor:default}
.shift-night-warn{margin:0 2px 14px;border:1px solid var(--gold);background:var(--gold-bg);color:var(--gold);border-radius:var(--r-md);padding:11px 13px;font-size:12px;font-weight:600;line-height:1.4}
.shift-night-warn b{color:var(--brand-bright)}
.chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:rgba(255,255,255,.05);border-radius:var(--r-pill);padding:4px 11px;font-size:12px;font-weight:600;color:var(--ink)}
.chip.muted{color:var(--ink-soft)}
.chip .dot{width:8px;height:8px;border-radius:50%;background:var(--brand)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.auto{display:flex;align-items:center;gap:8px;margin:0 2px 9px;background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 13px}
.auto .l{font-size:13px;color:var(--ink-soft);font-weight:700}
.auto .v{margin-left:auto;font-weight:600;font-size:15px}
.badge{font-size:9px;font-weight:600;letter-spacing:.4px;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line-strong);border-radius:6px;padding:1px 5px}
.result{display:flex;align-items:center;gap:8px;margin:2px 2px 9px;background:var(--card);border:1px solid var(--line-strong);border-left:4px solid var(--brand);border-radius:var(--r-md);padding:12px 13px;box-shadow:var(--shadow)}
.result .l{font-weight:600;font-size:14px}
.result .v{margin-left:auto;font-weight:600;font-size:19px;white-space:nowrap}
.result.big .v{font-size:22px}
.result.ok{border-left-color:var(--green)}
.result.ok .v{color:var(--green)}
.result.warn{border-left-color:var(--danger)}
.result.warn .v{color:var(--danger)}
.result .sub{display:block;font-size:11px;color:var(--ink-soft);font-weight:700;margin-top:2px}
.hint{font-size:11px;color:var(--ink-soft);margin:-4px 4px 10px;line-height:1.4}
.bar{height:9px;border-radius:6px;background:var(--track);overflow:hidden;margin:8px 2px 4px}
.bar>i{display:block;height:100%;border-radius:6px;background:var(--brand)}
.extra-box{border:1px solid var(--line);background:var(--card-2);border-radius:var(--r-md);padding:11px;margin:0 2px 9px}
.extra-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.extra-row{display:grid;grid-template-columns:110px 1fr auto;gap:7px;margin-top:7px}
.extra-row input{min-width:0;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:9px 10px;font-size:13px;font-weight:600;color:var(--ink)}
.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin:0 2px 10px}
.photo-input{display:block;border:1px solid var(--line);background:var(--card);border-radius:var(--r-md);padding:10px;box-shadow:var(--shadow);cursor:pointer}
.photo-input input{display:none}
.photo-input span{display:block;font-size:11px;color:var(--ink-soft);font-weight:600;margin-bottom:4px}
.photo-input b{display:block;font-size:12px;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.shift-footer{padding:12px 2px 2px}
.shift-footer .btn{width:100%;padding:14px;border:1px solid var(--brand);font-size:15px;font-weight:600}
.shift-error{margin:8px 2px;text-align:left}
.shift-notice{margin:8px 2px;text-align:left;border:1px solid var(--ok-line);background:var(--ok-bg);color:var(--green);border-radius:var(--r-md);padding:10px 12px;font-size:13px;font-weight:600}
.shift-cash-alert{margin:6px 2px 10px;border:1px solid var(--danger-line);background:var(--danger-bg);color:var(--danger);border-radius:var(--r-md);padding:10px 12px;font-size:12px;font-weight:600}
.shift-cash-alert b{color:var(--danger)}
.field-invalid{border-color:var(--danger) !important;box-shadow:0 0 0 2px var(--danger-bg)}
.dash{margin:0 0 16px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-lg);padding:12px}
.dash .monthbar{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}
.dash .mname{font-weight:600;color:var(--ink)}
.dash-top{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
@media(max-width:560px){.dash-top{grid-template-columns:1fr}}
.dash-metric{border:1px solid var(--line);background:var(--card-2);border-radius:var(--r-md);padding:10px}
.dash-metric span{display:block;font-size:11px;color:var(--ink-soft)}
.dash-metric b{display:block;font-family:var(--font-display);font-size:18px;color:var(--ink);margin:2px 0}
.dash-metric small{font-size:11px;color:var(--ink-soft)}
.dash-metric.ok b{color:var(--green)}
.dash-metric.warn b{color:var(--gold)}
.dash-weekdays{margin:10px 0;font-size:12px;color:var(--ink);line-height:1.5}
.dash-weekdays .dash-cap{display:block;font-size:11px;color:var(--ink-soft);margin-bottom:2px}
.dash-days{display:flex;flex-direction:column;gap:6px}
.dash-day{display:flex;align-items:baseline;justify-content:space-between;gap:8px;border-top:1px solid var(--line);padding-top:6px;font-size:12px}
.dash-day .dd-date{color:var(--ink-soft);min-width:64px}
.dash-day .dd-rev{color:var(--ink);font-weight:600}
.dash-day .dd-rev i{font-style:normal;font-size:11px;font-weight:600}
.dash-day .dd-rev i.up{color:var(--green)}
.dash-day .dd-rev i.down{color:var(--danger)}
.dash-day .dd-acc{color:var(--ink-soft);font-size:11px}
.auto-inp{background:var(--card-2);border-color:var(--line);box-shadow:none}
.phone.schedule-phone{max-width:none;border-radius:0}
.schedule-screen{padding:18px 14px 28px}
.monthbar{display:flex;align-items:center;gap:8px;margin:0 2px 12px}
.monthbar .mname{flex:1;text-align:center;font-weight:600;font-size:16px;text-transform:capitalize}
.btn{border:1px solid var(--line-strong);background:var(--card);color:var(--ink);border-radius:var(--r-md);padding:9px 12px;font:inherit;font-weight:700;font-size:14px;cursor:pointer;box-shadow:var(--shadow);transition:transform .08s ease,background .15s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}
.btn:active{transform:scale(.96)}
.btn.icon{width:42px;text-align:center;padding:9px 0;font-size:18px;line-height:1}
.schedule-lock-btn{margin-left:auto;white-space:nowrap}
.schedule-lock-btn.unlocked{background:var(--brand);border-color:var(--brand);color:var(--brand-ink)}
.schedule-screen.edit-locked .schedule-grid td.cell,
.schedule-screen.edit-locked .schedule-grid .markDate{cursor:default}
.gridwrap{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch}
.schedule-grid{border-collapse:separate;border-spacing:0;width:100%;min-width:max-content;font-size:12px}
.schedule-grid th,.schedule-grid td{border-right:1px solid var(--line);border-bottom:1px solid var(--line)}
.schedule-grid thead th{position:sticky;top:0;z-index:3;background:var(--card)}
.schedule-grid .colDate{position:sticky;left:0;z-index:2;background:var(--card);min-width:68px;width:68px}
.schedule-grid .markDate{cursor:pointer}
.schedule-grid thead .colDate{z-index:4}
.schedule-grid .dcell{padding:7px 6px;text-align:left;line-height:1.05}
.schedule-grid .dcell .dnum{font-weight:600;font-size:15px}
.schedule-grid .dcell .dwd{font-size:10px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.3px}
.schedule-grid .dmarks{display:flex;gap:3px;align-items:center;margin-top:3px;min-height:11px}
.markIcon{display:inline-flex;align-items:center;justify-content:center;min-width:13px;height:13px;padding:0 3px;color:var(--ink);font-size:10px;font-weight:600;line-height:1;border:1px solid var(--line-strong);border-radius:var(--r-sm);background:rgba(255,255,255,.05)}
.markIcon.star{font-size:11px;font-weight:700}
.schedule-grid tr.we .colDate,.schedule-grid tr.we td.cell{background:var(--weekend)}
.schedule-grid tr.we .dcell .dwd{color:var(--brand-bright)}
.schedule-grid tr.today .colDate{box-shadow:inset 3px 0 0 var(--brand)}
.schedule-grid th.emp{min-width:48px;width:48px;padding:7px 3px 8px;vertical-align:bottom;cursor:default}
.schedule-grid th.emp .nm{font-weight:600;font-size:12px;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:46px;margin:0 auto}
.schedule-grid th.emp .bar{height:4px;border-radius:3px;margin:5px 4px 0}
.schedule-grid th.emp .rl{font-size:9px;color:var(--ink-soft);margin-top:2px}
.schedule-grid td.cell{text-align:center;cursor:pointer;height:40px;user-select:none;position:relative;min-width:48px;width:48px}
.schedule-grid td.cell .h{display:inline-flex;align-items:center;justify-content:center;width:34px;height:28px;border-radius:var(--r-sm);font-weight:600;font-size:13px;position:relative;overflow:hidden;z-index:1}
.schedule-grid td.cell.on .h{color:var(--brand-ink)}
.schedule-grid td.cell .h.fx{font-size:10px;font-weight:600;letter-spacing:0}
.schedule-grid td.cell.payday::before{content:"";position:absolute;inset:1px;border:2px solid var(--payday);border-radius:5px;background:var(--brand-tint);pointer-events:none;z-index:0}
.schedule-grid td.cell .scoreDots{position:absolute;left:50%;bottom:2px;transform:translateX(-50%);display:flex;gap:2px;align-items:center;justify-content:center;z-index:2;pointer-events:none}
.scoreDot{display:inline-block;width:5px;height:5px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.55)}
.scoreDot.g{background:var(--score-good)}
.scoreDot.y{background:var(--score-mid)}
.scoreDot.r{background:var(--score-bad)}
.schedule-grid td.cell.payout .h{box-shadow:inset 0 0 0 2px var(--payout),inset 0 0 0 4px rgba(0,0,0,.5)}
.schedule-grid td.cell.payout .h::after,.schedule-grid td.cell.payoutEmpty .h::after{content:"";position:absolute;right:0;top:0;width:10px;height:10px;background:var(--payout);border-left:2px solid rgba(0,0,0,.6);border-bottom:2px solid rgba(0,0,0,.6);border-radius:0 8px 0 6px}
.schedule-grid td.cell.payoutEmpty .h{box-shadow:inset 0 0 0 2px var(--payout);background:transparent}
.schedule-grid .colSum{min-width:36px;width:36px;text-align:center;background:var(--card-2)}
.schedule-grid thead .colSum{background:var(--card-2)}
.schedule-grid .colSum .cv{font-weight:600;font-size:12px;color:var(--ink-soft)}
.schedule-grid .colMoney{min-width:64px;width:64px;text-align:right;background:var(--card-2);padding-right:8px}
.schedule-grid thead .colMoney{background:var(--card-2)}
.schedule-grid .colMoney .mv{font-weight:600;font-size:11px;color:var(--brand-bright)}
.schedule-grid .colPlan{min-width:76px;width:76px;text-align:right;background:var(--card-2);padding-right:8px}
.schedule-grid thead .colPlan{background:var(--card-2)}
.schedule-grid .colPlan .pv{font-weight:600;font-size:11px;color:var(--ink)}
.schedule-grid tfoot td{position:sticky;bottom:0;background:var(--card-2);z-index:2;border-top:2px solid var(--line-strong)}
.schedule-grid tfoot .colDate{z-index:3;background:var(--card-2);font-weight:600;font-size:11px}
.schedule-grid tfoot td.tt{text-align:center;font-weight:600;line-height:1.15;padding:5px 2px}
.schedule-grid tfoot td.tt .sh{font-size:13px}
.schedule-grid tfoot td.tt .hr{font-size:10px;color:var(--ink-soft);font-weight:700}
.schedule-grid tfoot td.tt .pay{font-size:11px;font-weight:600;color:var(--brand-bright);margin-top:1px}
.schedule-grid tfoot .colMoney.tt{text-align:right;padding-right:8px}
.schedule-grid tfoot .colMoney .paid{font-size:9px;color:var(--green);text-align:right;font-weight:700;margin-top:1px}
.schedule-grid tfoot .colMoney .rest{font-size:9px;color:var(--ink-soft);text-align:right;font-weight:700;margin-top:1px}
.schedule-grid tfoot .colPlan.tt{text-align:right;padding-right:8px}
.moneySummary{background:linear-gradient(135deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow);padding:14px 16px;margin:0 2px 12px}
.moneySummary.employee-money{background:var(--card)}
.moneySummary .msmain{display:flex;flex-direction:column;align-items:flex-start;gap:3px}
.moneySummary .mslabel{font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.moneySummary .msbig{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--brand-bright);white-space:nowrap}
.moneySummary .msrow{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-soft);font-weight:400}
.moneySummary .msrow b{color:var(--ink);font-weight:600}
.roleTotals{display:flex;flex-wrap:wrap;gap:8px;margin:6px 4px 0;font-size:12px;color:var(--ink-soft)}
.roleTotals .rt{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:4px 10px}
.roleTotals .dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:5px;vertical-align:middle}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:9px;margin-top:10px}
.scard{background:var(--card);border:1px solid var(--line);border-left-width:4px;border-radius:var(--r-md);padding:10px 12px;box-shadow:var(--shadow);min-width:0;overflow:hidden}
.scard .nm{font-weight:600;font-size:14px;line-height:1.15}
.scard .rl{font-size:11px;color:var(--ink-soft);margin-bottom:7px}
.scard .nums{display:flex;flex-wrap:wrap;gap:8px 12px;align-items:flex-end}
.scard .nums>div{min-width:58px;max-width:100%}
.scard .big{display:inline-block;max-width:100%;font-size:21px;font-weight:600;line-height:1;overflow-wrap:anywhere}
.scard .big.pay{font-size:19px}
.scard .unit{font-size:11px;color:var(--ink-soft);margin-left:3px;white-space:nowrap}
.scard .payMeta{width:100%;font-size:10px;color:var(--ink-soft);margin-top:5px;line-height:1.25}
.scard .scoreStats{width:100%;display:flex;gap:9px;align-items:center;margin-top:6px;font-size:11px;color:var(--ink-soft)}
.scard .scoreStats span{display:inline-flex;gap:4px;align-items:center;font-weight:600}
.total-card{padding:12px}
.money{font-weight:600;white-space:nowrap}
.editor-panel{margin-bottom:10px}
.editor-head{display:flex;align-items:flex-start;gap:10px;margin-bottom:12px}
.editor-grid{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:end}
.date-editor-panel{margin-bottom:10px}
.date-editor-grid{display:grid;grid-template-columns:auto minmax(210px,1fr) auto;gap:10px;align-items:end}
.date-editor-grid .checkrow{height:42px}
.save-error{margin-bottom:10px;color:var(--danger);border-color:var(--danger-line);font-size:13px;font-weight:600}
.field{display:block;min-width:0}
.field span{display:block;font-size:11px;color:var(--ink-soft);font-weight:600;margin:0 0 5px 2px}
.field input,.field textarea,.payout-add input{width:100%;min-width:0;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:10px 11px;font:inherit;font-size:14px;font-weight:600;color:var(--ink)}
.field textarea{min-height:72px;resize:vertical;font-weight:600}
.field select{min-width:0}
.admin-phone{max-width:980px}
.admin-screen{padding:18px 14px 28px}
.admin-layout{display:grid;grid-template-columns:280px 1fr;gap:10px;align-items:start}
.admin-list,.admin-form-panel{min-width:0}
.admin-list-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.admin-employees{display:grid;gap:7px;max-height:620px;overflow:auto;padding-right:2px}
.admin-employee{width:100%;text-align:left;border:1px solid var(--line);background:var(--card-2);border-radius:var(--r-sm);padding:10px 11px;color:var(--ink);cursor:pointer}
.admin-employee.on{border-color:var(--brand);box-shadow:inset 3px 0 0 var(--brand);background:var(--brand-tint)}
.admin-employee.off{opacity:.58}
.adm-name{display:block;font-size:13px;font-weight:600;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.adm-meta{display:block;font-size:11px;color:var(--ink-soft);font-weight:700;margin-top:3px;line-height:1.2}
.admin-form{display:grid;gap:12px}
.admin-save-state{font-size:12px;color:var(--ink-soft);font-weight:600}
.admin-fields{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:8px;align-items:end}
.schedule-settings{grid-template-columns:1.2fr 1fr .8fr .9fr}
.checkrow{display:flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ink-soft)}
.active-toggle{height:42px;white-space:nowrap}
.access-box{border-top:1px solid var(--line);padding-top:12px}
.access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:8px;margin-top:10px}
.access-row{border:1px solid var(--line);border-radius:var(--r-sm);background:var(--card-2);padding:10px;display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;min-width:0}
.access-title{display:flex;align-items:center;gap:7px;min-width:0;font-size:13px;font-weight:600}
.access-title>span:last-child{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.access-row label{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--ink-soft);white-space:nowrap}
.mini-icon{width:22px;height:22px;border-radius:7px;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;flex:none}
.mini-icon svg{width:14px;height:14px;stroke-width:2.2}
.admin-actions{display:flex;justify-content:flex-end;gap:8px}
.admin-form-error{margin:0;text-align:left;min-height:0}
.admin-tech{display:flex;align-items:center;gap:10px;margin-top:10px}
.fixed-pay-row{display:grid;grid-template-columns:repeat(4,1fr);gap:7px;margin:10px 0 2px}
.fixed-pay{border:1px solid var(--line-strong);background:var(--card-2);border-radius:var(--r-md);padding:10px 4px;font:inherit;font-size:13px;font-weight:600;color:var(--ink);cursor:pointer}
.fixed-pay.on{background:var(--dish);border-color:var(--dish);color:var(--brand-ink)}
.toggle-row{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0 10px;color:var(--ink-soft);font-size:13px;font-weight:600}
.toggle-row label{display:flex;align-items:center;gap:6px}
.score-row{display:flex;align-items:center;gap:8px;margin:10px 0 12px}
.score-pick{width:32px;height:32px;border-radius:50%;border:1px solid var(--line-strong);background:var(--card);display:flex;align-items:center;justify-content:center;cursor:pointer}
.score-pick::after{content:"";width:10px;height:10px;border-radius:50%;display:block;background:var(--ink-soft)}
.score-pick.green::after{background:var(--green)}
.score-pick.yellow::after{background:var(--gold)}
.score-pick.red::after{background:var(--score-bad)}
.score-pick.on{border-color:var(--ink);box-shadow:0 0 0 2px rgba(255,255,255,.12)}
.payout-editor{border-top:1px solid var(--line);padding-top:10px}
.payout-item{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:var(--r-sm);padding:7px 8px;margin-top:7px;font-size:13px;font-weight:600}
.payout-item .payout-period{font-style:normal;font-weight:600;color:var(--ink-soft);font-size:12px}
.payout-item-actions{margin-left:auto;display:flex;gap:6px;flex:none}
.payout-item.editing{flex-wrap:wrap}
.payout-edit{display:flex;flex-wrap:wrap;gap:7px;align-items:center;width:100%}
.payout-edit input{flex:1 1 100px;min-width:0;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:8px 10px;color:var(--ink);font:inherit;font-size:14px;font-weight:600}
.payout-edit select{flex:1 1 130px;min-width:0}
.payout-add{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px;align-items:center}
.payout-add>select,.payout-add>input{flex:1 1 140px;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:10px 11px;color:var(--ink);font:inherit;font-size:14px;font-weight:500;min-width:0}
.payout-add>button{flex:1 1 100%}
.muted-line{font-size:12px;color:var(--ink-soft);margin-top:7px}
.requisition-phone{max-width:none}
.requisition-screen{max-width:980px;margin:0 auto}
.req-note{border:1px solid var(--line);background:var(--card-2);color:var(--ink-soft);font-size:12px;font-weight:600;line-height:1.35;padding:10px 12px;margin:0 2px 10px}
.req-note,.req-tabs button,.req-search input,.req-chip,.req-item,.req-add,.req-stepper,.req-submit-link,.req-summary>div,.req-cart-line,.req-record,.req-record-head select,.req-status,.req-record-lines span,.req-notice{border-radius:var(--r-sm)}
.req-tabs{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin:0 2px 12px}
.req-tabs button,.req-segment button{border:1px solid var(--line-strong);background:var(--card);color:var(--ink-soft);font-weight:600;cursor:pointer}
.req-tabs button{padding:10px 12px}
.req-tabs button.on,.req-segment button.on{background:var(--brand);border-color:var(--brand);color:var(--brand-ink)}
.req-tabs b{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;margin-left:5px;border-radius:var(--r-sm);background:rgba(255,255,255,.22);font-size:11px}
.req-toolbar{display:grid;grid-template-columns:auto minmax(0,1fr);gap:8px;margin:0 2px 10px}
.req-segment{display:grid;grid-template-columns:1fr 1fr;border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line-strong);background:var(--card)}
.req-segment button{border:0;border-right:1px solid var(--line-strong);padding:10px 12px}
.req-segment button:last-child{border-right:0}
.req-search input{width:100%;height:42px;border:1px solid var(--line-strong);background:var(--card);color:var(--ink);font-weight:600;padding:0 12px}
.req-categories{display:flex;gap:7px;overflow:auto;margin:0 2px 12px;padding-bottom:3px;-webkit-overflow-scrolling:touch}
.req-chip{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--card);color:var(--ink);padding:7px 9px;white-space:nowrap;cursor:pointer;font-size:12px;font-weight:600;flex:none}
.req-chip i{width:7px;height:7px;border-radius:50%;background:var(--ink-soft);flex:none}
.req-chip b{color:var(--ink-soft);font-size:11px}
.req-chip.on{border-color:var(--brand);box-shadow:inset 0 0 0 1px var(--brand);background:var(--brand-tint);color:var(--ink)}
.req-current{display:flex;justify-content:space-between;align-items:center;gap:8px;margin:0 4px 8px;font-size:12px;color:var(--ink-soft);font-weight:600}
.req-current b{color:var(--ink)}
.req-items{display:grid;gap:7px;margin:0 2px 82px}
.req-item,.req-cart-line,.req-record{border:1px solid var(--line);background:var(--card);padding:10px 11px}
.req-item{display:grid;grid-template-columns:auto 1fr auto;gap:9px;align-items:center}
.req-item.selected{border-color:var(--brand-line);background:var(--brand-tint)}
.req-marker{width:8px;height:28px;border-radius:4px;display:block}
.req-item-main{display:block;min-width:0}
.req-item-main b{display:block;font-size:14px;line-height:1.2;overflow-wrap:anywhere}
.req-item-main small{display:block;margin-top:3px;color:var(--ink-soft);font-size:11px;font-weight:600;line-height:1.2}
.req-add{width:34px;height:34px;border:1px solid var(--brand);background:var(--brand);color:var(--brand-ink);font-size:22px;line-height:1;font-weight:600;cursor:pointer}
.req-stepper{display:inline-grid;grid-template-columns:30px minmax(64px,auto) 30px;align-items:center;border:1px solid var(--brand-line);background:var(--card);overflow:hidden}
.req-stepper button{height:38px;border:0;background:var(--brand-tint);color:var(--brand-bright);font-weight:700;font-size:17px;cursor:pointer}
.req-stepper b{text-align:center;padding:0 8px;font-size:12px;white-space:nowrap;color:var(--ink)}
.req-sticky{position:sticky;bottom:10px;margin:0 2px 10px;z-index:5}
.req-submit-link{width:100%;min-height:45px;border:1px solid var(--brand);padding:12px 14px;font-weight:700;cursor:pointer;box-shadow:0 10px 24px rgba(0,0,0,.5)}
.req-submit-link:disabled{opacity:.48;cursor:default;box-shadow:none}
.req-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0 2px 12px}
.req-summary>div{border:1px solid var(--line);background:var(--card);padding:10px}
.req-summary span{display:block;color:var(--ink-soft);font-size:11px;font-weight:600}
.req-summary b{display:block;margin-top:4px;font-size:16px;line-height:1.1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.req-free{margin:0 2px 12px}
.req-free-grid{display:grid;grid-template-columns:.8fr 1fr minmax(180px,1.6fr) .7fr .65fr auto;gap:8px;align-items:end;margin-top:10px}
.req-free-name{min-width:0}
.req-cart-groups{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 2px 12px}
.req-cart-group{min-width:0}
.req-group-title{display:flex;justify-content:space-between;align-items:center;margin:0 2px 7px;color:var(--ink-soft);font-size:12px;font-weight:700}
.req-cart-line{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;margin-bottom:7px}
.req-comment{display:block;margin:0 2px 10px}
.req-urgent{margin:0 4px 12px}
.req-history{display:grid;gap:8px;margin:0 2px}
.req-record{display:grid;gap:8px}
.req-record-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.req-record-head b{display:block;font-size:14px;line-height:1.2}
.req-record-head small{display:block;color:var(--ink-soft);font-size:11px;font-weight:600;margin-top:3px}
.req-record-head select{color:var(--ink);font-size:12px;font-weight:500;height:34px;padding:0 30px 0 10px;max-width:150px}
.req-status{font-style:normal;font-size:11px;font-weight:700;color:var(--green);background:var(--ok-bg);border:1px solid var(--ok-line);padding:5px 8px;white-space:nowrap}
.req-status.rejected{color:var(--danger);background:var(--danger-bg);border-color:var(--danger-line)}
.req-status.purchased{color:var(--brand-bright);background:var(--brand-tint);border-color:var(--brand-line)}
.req-record-meta{font-size:11px;color:var(--ink-soft);font-weight:600}
.req-record-lines{display:flex;flex-wrap:wrap;gap:5px}
.req-record-lines span{font-size:11px;color:var(--ink-soft);border:1px solid var(--line);background:var(--card-2);padding:4px 7px}
.req-record-lines b{color:var(--ink)}
.req-record-comment{font-size:12px;color:var(--ink-soft);line-height:1.35;border-top:1px solid var(--line);padding-top:8px}
.req-record-actions{display:flex;gap:8px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:9px}
.req-edit-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;border:1px solid var(--brand-line);background:var(--brand-tint);color:var(--brand-bright);border-radius:var(--r-sm);padding:9px 12px;margin:0 2px 10px;font-size:12px;font-weight:600}
.req-notice{margin:10px 2px 0;border:1px solid var(--ok-line);background:var(--ok-bg);color:var(--green);font-size:12px;font-weight:700;padding:10px 12px}
.req-error{margin:10px 2px 0;text-align:left}
.tasks-phone{max-width:none}
.tasks-screen{max-width:860px;margin:0 auto}
.task-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0 2px 12px}
.task-metric{border:1px solid var(--line);background:var(--card);padding:11px 12px}
.task-metric span{display:block;font-size:11px;color:var(--ink-soft);font-weight:600}
.task-metric b{display:block;font-size:22px;line-height:1;margin-top:5px;color:var(--brand-bright)}
.task-create{margin:0 2px 12px}
.task-create-grid{display:grid;grid-template-columns:minmax(170px,.9fr) minmax(220px,1.6fr) minmax(140px,.8fr) auto;gap:8px;align-items:end;margin-top:10px}
.task-list{display:grid;gap:8px;margin:0 2px}
.task-card{display:flex;justify-content:space-between;align-items:center;gap:12px;border:1px solid var(--line);background:var(--card);padding:12px}
.task-card.done{opacity:.72}
.task-main{min-width:0}
.task-title{font-size:14px;font-weight:600;line-height:1.25;overflow-wrap:anywhere}
.task-desc{margin-top:5px;font-size:12px;line-height:1.4;color:var(--ink-soft);font-weight:400;white-space:pre-wrap;overflow-wrap:anywhere}
.task-create-grid .task-desc-field{grid-column:1/-1}
.task-create-grid .task-reward-field{grid-column:1/-1}
.task-reward-row{display:flex;flex-direction:column;align-items:stretch;gap:10px}
.task-reward-row .reward-check{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-weight:500;color:var(--ink-soft);font-size:13px;line-height:1.3;cursor:pointer}
.task-reward-row .reward-check input{flex:none}
.task-reward-row input[type=number]{width:100%;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:10px 11px;color:var(--ink);font:inherit;font-size:14px;font-weight:500}
.task-reward{color:var(--gold);font-weight:700}
.req-urgent-toggle{display:inline-block;margin-top:6px;border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);border-radius:var(--r-pill);padding:3px 11px;font-size:11px;font-weight:600;cursor:pointer}
.req-urgent-toggle.on{border-color:var(--gold);background:var(--gold-bg);color:var(--gold)}
.req-item-controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:8px}
.req-item-controls .req-urgent-toggle{margin-top:0}
.req-cart-line.minimal{grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:8px 11px}
.req-cart-name{font-size:13px;line-height:1.25;overflow-wrap:anywhere}
.req-cart-name.urgent{color:var(--gold);font-weight:600}
.req-cart-qty{font-size:12px;color:var(--ink);white-space:nowrap}
.req-cart-x{border:0;background:transparent;color:var(--ink-soft);font-size:14px;cursor:pointer;padding:10px 12px;margin:-8px -7px;line-height:1}
.req-cart-x:hover{color:var(--danger)}
.req-expand{border:0;background:transparent;color:var(--brand);font:inherit;font-size:11px;font-weight:700;cursor:pointer;padding:5px 4px;text-decoration:underline;width:100%;text-align:left}
.req-record-lines.checklist{flex-direction:column;gap:6px}
.req-record-lines.checklist span{border:0;background:transparent;padding:0;color:inherit;font-size:12px}
.req-line-check{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;background:var(--card-2);border:1px solid var(--line);padding:7px 9px;border-radius:var(--r-sm)}
.req-line-check .rlc-main{display:flex;align-items:center;gap:9px;cursor:pointer;flex:1 1 auto;min-width:0}
.req-line-check input[type=checkbox]{width:20px;height:20px;accent-color:var(--green);flex:0 0 auto;cursor:pointer}
.req-line-check .rlc-main span{overflow-wrap:anywhere;color:var(--ink-soft)}
.req-line-check.done{border-color:var(--ok-line);background:var(--ok-bg)}
.req-line-check.done .rlc-main span{color:var(--green);text-decoration:line-through}
.rlc-bought{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--ink-soft);white-space:nowrap}
.rlc-bought input{width:64px;border:1px solid var(--line-strong);background:var(--card);border-radius:7px;padding:5px 7px;color:var(--ink);font:inherit;font-size:13px;font-weight:600}
.rlc-diff{font-style:normal;color:var(--gold);font-size:11px;font-weight:600}
.req-record-lines span.bought{color:var(--green);border-color:var(--ok-line);background:var(--ok-bg)}
.req-record-lines span.bought b{color:var(--green)}
.req-history-head{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:0 2px}
.req-history-head h2{margin:0}
.req-filter-toggle{border:1px solid var(--line-strong);background:transparent;color:var(--ink-soft);border-radius:var(--r-pill);padding:5px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap}
.req-filter-toggle.on{border-color:var(--brand);background:var(--brand-tint);color:var(--brand-bright)}
.cost-summary{border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);padding:12px 14px;margin:0 2px 12px}
.cost-summary-head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:10px}
.cost-summary-head span{font-family:var(--font-display);font-weight:700;font-size:13px}
.cost-summary-head b{font-size:12px;color:var(--ink-soft);white-space:nowrap}
.cost-row{margin-bottom:10px}
.cost-row:last-child{margin-bottom:0}
.cost-row-top{display:flex;justify-content:space-between;gap:8px;font-size:12px}
.cost-row-top span{color:var(--ink-soft)}
.cost-row-top b{color:var(--ink);white-space:nowrap}
.meter{height:8px;border-radius:5px;background:var(--track);overflow:hidden}
.meter>i{display:block;height:100%;border-radius:5px;background:var(--brand);transition:width .2s ease}
.meter.thin{height:6px}
.meter.big{height:10px}
.meter.ok>i{background:var(--green)}
.meter.danger>i{background:var(--danger)}
.cost-row.over .meter>i{background:var(--danger)}
.cost-row-sub{font-size:11px;color:var(--ink-soft)}
.cost-row.over .cost-row-sub{color:var(--danger);font-weight:600}
.req-record-lines span.urgent{border-color:var(--gold);color:var(--gold)}
.handover-create textarea{width:100%;border:1px solid var(--line-strong);background:var(--card-2);border-radius:var(--r-sm);padding:10px 11px;color:var(--ink);font:inherit;font-size:14px;font-weight:400;resize:vertical;min-height:54px}
.handover-create-row{display:flex;align-items:center;gap:10px;margin-top:10px;flex-wrap:wrap}
.handover-create-row select{flex:1;min-width:150px}
.handover-create-row .ghost{white-space:nowrap}
.handover-aud-fixed{flex:1;font-size:12px;color:var(--ink-soft);font-weight:500}
.handover-list{display:grid;gap:8px;margin:10px 2px 0}
.handover-note{border:1px solid var(--line);background:var(--card);border-radius:var(--r-md);padding:12px 13px}
.handover-note.from-manager{border-color:var(--brand-line);background:var(--brand-tint)}
.handover-note-body{font-size:14px;line-height:1.45;color:var(--ink);white-space:pre-wrap;overflow-wrap:anywhere}
.handover-note-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:9px;flex-wrap:wrap}
.handover-note-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--ink-soft);font-weight:500}
.handover-badge{border:1px solid var(--line-strong);border-radius:var(--r-pill);padding:3px 9px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--ink-soft)}
.handover-badge.manager{border-color:var(--brand-line);color:var(--brand-bright)}
.praise-list{display:grid;gap:8px;margin:0 2px}
.praise-item{border:1px solid var(--line);background:var(--card);border-left:3px solid var(--brand);border-radius:var(--r-md);padding:12px 13px}
.praise-body{font-size:14px;line-height:1.45;color:var(--ink);white-space:pre-wrap;overflow-wrap:anywhere}
.praise-meta{margin-top:7px;font-size:11px;color:var(--ink-soft);font-weight:500}
.praise-meta b{color:var(--ink);font-weight:700}
.schedule-grid td.cell.bday{box-shadow:inset 0 0 0 2px var(--brand-bright)}
.schedule-grid td.cell.bday .bday-mark{position:absolute;left:2px;top:2px;display:inline-flex;align-items:center;gap:2px;font-size:10px;font-weight:800;line-height:1;color:var(--brand-ink);background:var(--brand-bright);border-radius:5px;padding:2px 4px;z-index:2;pointer-events:none;box-shadow:0 1px 3px rgba(0,0,0,.45)}
.schedule-grid td.cell.bday .bday-mark i{font-style:normal;font-size:11px}
/* Единая верхняя подложка: цель дня + 3 плановых блока */
.day-panel{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px;margin:4px 2px 10px;box-shadow:var(--shadow)}
.day-goal{font-size:13px;line-height:1.4;color:var(--ink-soft);font-weight:400;margin-bottom:12px}
.day-blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.day-block{background:var(--card-2);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 9px;text-align:left;color:var(--ink);min-width:0}
button.day-block{cursor:pointer;font:inherit}
.day-block span{display:block;font-size:11px;color:var(--ink-soft);font-weight:500;line-height:1.2;min-height:2.4em}
.day-block b{display:block;font-family:var(--font-display);font-weight:700;font-size:13px;letter-spacing:-.02em;color:var(--brand-bright);margin-top:6px;white-space:nowrap;font-feature-settings:"tnum" 1}

/* Заслуги */
.merits{display:grid;gap:8px;margin:0 2px}
.merit-top{display:grid;grid-template-columns:1.55fr 1fr;gap:8px}
.award{display:flex;align-items:center;gap:12px;background:linear-gradient(135deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:var(--r-lg);padding:13px 14px;min-width:0}
.award-empty{background:var(--card)}
.award-icon{position:relative;flex:none;color:var(--brand);display:flex;align-items:center;justify-content:center}
.award-icon.mask{width:48px;height:48px}
.mask-img{width:100%;height:100%;object-fit:contain;display:block}
.prog-badge.mask{transform:none;width:158px;height:158px;margin:8px auto 14px}
.prog-badge .mask-img{filter:drop-shadow(0 0 13px var(--brand))}

/* Обучение: модульная навигация + тесты */
.training-module-nav{margin-bottom:12px}
.tmn-title{font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--brand-bright);margin:4px 2px 7px}
.training-chapter-btn.locked{opacity:.55}
.training-chapter-btn.passed{border-color:var(--ok-line)}
.training-chapter-btn.passed i{color:var(--green)}
.training-attest{display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;border:1px dashed var(--line-strong);border-radius:var(--r-sm);padding:9px 11px;margin-top:6px;font-size:13px;font-weight:600;color:var(--ink);background:transparent;text-align:left;cursor:default}
.training-attest i{font-style:normal;font-size:11px;font-weight:600;color:var(--ink-soft)}
.training-attest.open{border-style:solid;border-color:var(--brand);cursor:pointer}
.training-attest.open i{color:var(--brand-bright)}
.training-attest.passed{border-color:var(--ok-line)}.training-attest.passed i{color:var(--green)}
.quiz-gate{border:1px solid var(--brand-line);background:var(--brand-tint);border-radius:var(--r-md);padding:14px;margin-top:16px}
.quiz-gate-info{font-size:13px;line-height:1.5;color:var(--ink);margin-bottom:11px}
.quiz-gate.passed{border-color:var(--ok-line);background:var(--ok-bg);color:var(--green);font-weight:600}
.quiz-gate.fail{border-color:var(--danger-line);background:var(--danger-bg);color:var(--danger);font-weight:600}
.quiz-gate.locked{border-style:dashed;border-color:var(--line-strong);background:transparent;color:var(--ink-soft);font-weight:500}
.chapter-footer{margin-top:18px;display:flex;flex-direction:column;gap:10px;align-items:stretch}
.chapter-footer .quiz-gate-info.soft{color:var(--ink-soft);margin:0;text-align:center}
.route-done-bar{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:11px 14px;border:1px dashed var(--line-strong);border-radius:var(--r-md);color:var(--ink-soft);font-size:13px}
.route-done-btn{width:auto;margin-top:14px;padding:9px 16px}
.linklike{background:none;border:none;color:var(--brand);font:inherit;cursor:pointer;padding:0;text-decoration:underline}
.quiz-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 2px 8px}
.quiz-title{font-family:var(--font-display);font-weight:700;font-size:18px}
.quiz-timer{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--brand-bright);border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);padding:6px 12px;font-feature-settings:"tnum" 1}
.quiz-timer.low{color:var(--danger);border-color:var(--danger-line)}
.quiz-questions{display:grid;gap:10px}
.quiz-q{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px}
.quiz-q-prompt{font-size:14px;font-weight:600;line-height:1.4;margin-bottom:10px}
.quiz-opts{display:grid;gap:7px}
.quiz-opt{display:flex;align-items:flex-start;gap:9px;border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 12px;cursor:pointer;font-size:13px;line-height:1.4}
.quiz-opt input{margin-top:2px;flex:none}
.quiz-opt:has(input:checked){border-color:var(--brand);background:var(--brand-tint)}
.quiz-result{max-width:420px;margin:40px auto;text-align:center;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 20px}
.quiz-result.ok{border-color:var(--ok-line)}
.quiz-result.fail{border-color:var(--danger-line)}
.quiz-score{font-family:var(--font-display);font-weight:700;font-size:48px;line-height:1;color:var(--brand-bright)}
.quiz-result.fail .quiz-score{color:var(--danger)}
.quiz-result.ok .quiz-score{color:var(--green)}
.quiz-verdict{font-family:var(--font-display);font-weight:700;font-size:18px;margin-top:8px}
.quiz-result p{font-size:13px;color:var(--ink-soft);line-height:1.5;margin:10px 0 18px}
.quiz-result .btn{width:100%}
.award-lvl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding-bottom:3px;font-family:var(--font-display);font-weight:700;font-size:11px;color:var(--brand-ink)}
.award-meta{min-width:0}
.award-meta b{display:block;font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--ink)}
.award-meta span{display:block;font-size:12px;color:var(--ink-soft);font-weight:400;margin-top:2px;line-height:1.3}
.award-bar{margin-top:8px}
.merit-tasks{display:flex;flex-direction:column;justify-content:center;gap:5px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:13px 14px;text-align:left;color:var(--ink);cursor:pointer;font:inherit;min-width:0}
.merit-tasks span{font-size:12px;color:var(--ink-soft);font-weight:500;line-height:1.2}
.merit-tasks b{font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--brand-bright)}
.merit-badges{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.badge-stat{display:flex;flex-direction:column;align-items:flex-start;gap:4px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 12px;min-width:0}
.badge-stat .bi{color:var(--brand-bright);display:flex}
.badge-stat .bs-num{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--ink)}
.badge-stat .bs-num .mult{font-size:12px;color:var(--ink-soft);margin-right:4px}
.badge-stat .bs-lbl{font-size:11px;color:var(--ink-soft);font-weight:500}
.badge-praise{align-items:center;justify-content:center;text-align:center;cursor:pointer;font:inherit;gap:6px}
.badge-praise .praise-plus{font-family:var(--font-display);font-size:24px;line-height:1;color:var(--brand-bright)}
.badge-praise .bs-lbl{font-weight:600;color:var(--ink)}

/* Цели по продажам (главная) */
.sales-goals{display:grid;gap:8px;margin:0 2px 10px}
.goal-card{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:var(--r-lg);padding:13px 14px;box-shadow:var(--shadow)}
.goal-card.reached{border-color:var(--brand-line);background:var(--brand-tint)}
.goal-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.goal-title{font-weight:600;font-size:14px;color:var(--ink);min-width:0}
.goal-reward{color:var(--gold);font-weight:700;font-size:12px;white-space:nowrap}
.goal-count{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--ink-soft);white-space:nowrap}
.goal-count b{color:var(--brand-bright);font-size:19px}
.goal-bar{margin:10px 0 0}
.goal-status{margin-top:10px;font-size:12px;font-weight:600;color:var(--brand-bright)}
.goal-actions{display:flex;gap:8px;margin-top:11px}
.goal-plus{flex:1}

/* Страница прогресса */
.plan-met-btn{width:auto;margin:0 2px 12px;padding:8px 13px;font-size:12.5px}
.bday-banner{background:var(--brand-tint);border:1px solid var(--brand-line);border-radius:var(--r-lg);padding:14px 16px;margin:0 2px 12px}
.bday-banner.self{background:var(--brand);border-color:var(--brand-bright);color:var(--brand-ink)}
.bday-banner .bb-title{font-family:var(--font-display);font-weight:700;font-size:15px;line-height:1.25}
.bday-banner .bb-sub{font-size:13px;margin-top:4px;opacity:.92}
.bday-banner .bb-btn{margin-top:10px;width:auto;padding:8px 14px;font-size:13px}
.oblig-list{display:flex;flex-direction:column;gap:10px}
.oblig-card{background:var(--card);border:1px solid var(--brand-line);border-radius:var(--r-lg);padding:13px 15px}
.oblig-card.manage{border-color:var(--line)}
.oblig-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.oblig-title{font-weight:600;color:var(--ink)}
.oblig-remain{font-family:var(--font-display);font-weight:700;color:var(--brand-bright);white-space:nowrap}
.oblig-note{font-size:13px;color:var(--ink-soft);margin-top:3px}
.oblig-bar{margin:9px 0 6px}
.oblig-sub{font-size:12.5px;color:var(--ink-soft)}
.oblig-actions{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.oblig-actions input{flex:1;min-width:120px}
.oblig-actions .btn{width:auto;padding:8px 12px;font-size:13px}
.progress-next{display:flex;align-items:center;gap:12px;border:1px dashed var(--line-strong);border-radius:var(--r-lg);padding:13px 14px;margin:0 2px 10px;opacity:.75}
.prog-lock{color:var(--ink-soft);flex:none;display:flex}
.progress-next b{display:block;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--ink-soft)}
.progress-next span{display:block;font-size:12px;color:var(--ink-soft);margin-top:2px}
.progress-hero{background:linear-gradient(135deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:var(--r-lg);padding:18px 16px 22px;margin:0 2px 14px;text-align:center}
.prog-badge{position:relative;display:inline-flex;align-items:center;justify-content:center;color:var(--brand);transform:scale(2.2);transform-origin:center;margin:10px 0 18px}
.prog-badge .award-lvl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding-bottom:2px;font-family:var(--font-display);font-weight:700;font-size:10px;color:var(--brand-ink)}
.prog-title{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--ink)}
.award-bar.big{max-width:320px;margin:14px auto 0}
.prog-sub{font-size:12px;color:var(--ink-soft);font-weight:500;margin-top:8px}
.prog-hero-row{display:flex;align-items:flex-end;justify-content:center;gap:7px}
.prog-hero-row .prog-badge.mask{flex:none;margin:0 0 12px}
.totem-slot{appearance:none;width:64px;height:64px;flex:none;margin-bottom:12px;border:0;background:none;color:var(--ink);display:flex;align-items:flex-end;justify-content:center;padding:0;cursor:pointer;transition:transform .15s,filter .15s}
.totem-slot.active{transform:translateY(-3px)}
.totem-slot.empty{visibility:hidden}
.totem-img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 2px 5px rgba(0,0,0,.55))}
.totem-slot.active .totem-img{filter:drop-shadow(0 0 8px var(--brand))}
.totem-detail{margin:14px auto 0;max-width:320px;background:var(--card);border:1px solid var(--brand-line);border-radius:var(--r-md);padding:10px 14px;text-align:center}
.totem-detail b{display:block;font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--brand-bright)}
.totem-detail span{display:block;font-size:12px;color:var(--ink-soft);margin-top:4px;line-height:1.45}
.progress-team{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px;margin:0 2px 14px}
.pteam-card{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:10px 12px;min-width:0}
.pteam-mask{width:42px;height:42px;flex:none}
.pteam-mask .mask-img{width:100%;height:100%;object-fit:contain;display:block}
.pteam-info{min-width:0}
.pteam-info b{display:block;font-size:14px;font-weight:600;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.pteam-info span{display:block;font-size:12px;color:var(--brand-bright);font-weight:600;margin-top:2px}
.progress-history{display:grid;gap:7px;margin:0 2px}
.ph-item{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:11px 13px}
.ph-pts{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--brand-bright);flex:none;min-width:46px}
.ph-main{min-width:0}
.ph-main b{display:block;font-size:14px;font-weight:600;color:var(--ink)}
.ph-main span{display:block;font-size:11px;color:var(--ink-soft);font-weight:400;margin-top:2px}
.task-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:5px;font-size:11px;color:var(--ink-soft);font-weight:600}
.task-actions{display:flex;gap:7px;align-items:center;flex:none}
.task-title-row{display:flex;align-items:center;gap:9px}
.task-title-row .task-title{flex:1;min-width:0}
.task-status{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:4px 9px;border:1px solid var(--line-strong);border-radius:var(--r-pill);white-space:nowrap;flex:none}
.task-status.open{color:var(--gold);background:var(--gold-bg)}
.task-status.done{color:var(--green);background:var(--ok-bg)}
.training-phone{max-width:none}
.training-screen{max-width:1120px;margin:0 auto}
.training-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(150px,220px);gap:14px;align-items:end;border:1px solid var(--line);background:linear-gradient(135deg,var(--card),var(--card-2));padding:16px;margin:0 2px 12px}
.training-kicker{display:block;color:var(--ink-soft);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.training-hero h2,.training-article h2{font-family:var(--font-display);font-size:22px;line-height:1.1;font-weight:700;margin:0}
.training-hero p,.training-article-head p{margin:8px 0 0;color:var(--ink-soft);font-size:13px;line-height:1.45;font-weight:700}
.training-progress{text-align:right}
.training-progress b{display:block;font-family:var(--font-display);font-size:30px;line-height:1;font-weight:700;color:var(--brand-bright)}
.training-progress span{display:block;color:var(--ink-soft);font-size:12px;font-weight:600;margin-top:5px}
.training-challenge{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:0 2px 12px;padding:12px 15px;border:1px solid var(--brand-line);background:var(--brand-tint);border-radius:var(--r-sm)}
.training-challenge .tc-text b{display:block;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--ink)}
.training-challenge .tc-text span{display:block;font-size:12px;color:var(--ink-soft);margin-top:2px;line-height:1.35}
.training-challenge .btn{width:auto;padding:9px 18px;flex:0 0 auto}
.training-challenge .btn:disabled{opacity:.5;cursor:default}
.training-manager{border:1px solid var(--line);background:var(--card);padding:14px;margin:0 2px 12px}
.training-manager-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.training-manager .sec{margin:0 0 4px}
.training-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:10px}
.training-metrics>div{border:1px solid var(--line);background:var(--card-2);padding:10px}
.training-metrics span{display:block;color:var(--ink-soft);font-size:11px;font-weight:700}
.training-metrics b{display:block;font-size:20px;line-height:1;margin-top:5px;color:var(--brand-bright)}
.training-team{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:7px}
.training-person{display:grid;grid-template-columns:minmax(0,1fr) 88px;gap:10px;align-items:center;border:1px solid var(--line);background:var(--card-2);padding:10px}
.training-person-main b{display:block;font-size:13px;line-height:1.15;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.training-person-main span{display:block;color:var(--ink-soft);font-size:11px;font-weight:600;margin-top:3px}
.training-person-progress{display:grid;grid-template-columns:1fr auto;gap:6px;align-items:center}
.training-person-progress i{display:block;height:7px;border-radius:5px;background:var(--track);overflow:hidden}
.training-person-progress i span{display:block;height:100%;border-radius:5px;background:var(--brand)}
.training-person-progress b{font-size:11px;color:var(--ink-soft)}
.training-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:12px;align-items:start}
.training-side,.training-main{min-width:0}
.training-route,.training-chapters,.training-article{border:1px solid var(--line);background:var(--card);padding:13px}
.training-route .sec{margin:0 0 10px}
.training-days{display:grid;gap:9px}
.training-day{display:grid;grid-template-columns:30px minmax(0,1fr);gap:9px}
.training-day-num{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--brand);color:var(--brand-ink);font-family:var(--font-display);font-weight:700;font-size:13px}
.training-day-body b{display:block;font-size:13px;line-height:1.2;margin-bottom:6px}
.training-route-item{display:block;width:100%;text-align:left;border:0;border-top:1px solid var(--line);background:transparent;padding:7px 0;color:var(--ink-soft);font-size:12px;font-weight:600;line-height:1.25;cursor:pointer}
.training-route-item.read span::after{content:" · прочитано";color:var(--green)}
.training-chapters{display:grid;gap:7px}
.training-chapter-btn{width:100%;display:flex;justify-content:space-between;align-items:center;gap:10px;text-align:left;border:1px solid var(--line);background:var(--card-2);color:var(--ink);padding:10px;cursor:pointer}
.training-chapter-btn.on{border-color:var(--brand);box-shadow:inset 3px 0 0 var(--brand);background:var(--brand-tint)}
.training-chapter-btn.read{border-color:var(--ok-line)}
.training-chapter-btn span{font-size:13px;font-weight:700;line-height:1.2;overflow-wrap:anywhere}
.training-chapter-btn i{font-style:normal;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--ink-soft);white-space:nowrap}
.training-chapter-btn.read i{color:var(--green)}
.training-article{min-height:520px}
.training-article-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:12px}
.training-article-head .ghost:disabled{opacity:.55;cursor:default;background:var(--ok-bg);border-color:var(--ok-line);color:var(--green)}
.training-attachments{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:8px;margin-bottom:12px}
.training-attachment{display:flex;justify-content:space-between;gap:10px;align-items:center;border:1px solid var(--line);background:var(--card-2);padding:10px;color:var(--ink)}
.training-attachment b{display:block;font-size:13px;line-height:1.2}
.training-attachment small{display:block;font-size:11px;color:var(--ink-soft);font-weight:600;line-height:1.25;margin-top:3px}
.training-attachment i{font-style:normal;font-size:11px;color:var(--brand-bright);font-weight:700;white-space:nowrap}
.training-attachment.muted i{color:var(--ink-soft)}
.training-body{font-size:14px;line-height:1.58;color:var(--ink)}
.training-body h3{font-size:16px;margin:20px 0 8px;font-weight:700}
.training-body p{margin:0 0 10px}
.training-body ul{margin:0 0 13px 18px;padding:0}
.training-body li{margin:0 0 7px}
.training-step{font-weight:600;color:var(--brand-bright)}
.payroll-phone{max-width:none}
.payroll-screen{max-width:760px;margin:0 auto}
.payroll-hero{display:flex;justify-content:space-between;gap:14px;align-items:flex-end;border:1px solid var(--line);background:linear-gradient(135deg,var(--card),var(--card-2));padding:16px;margin:0 2px 12px}
.payroll-balance{font-family:var(--font-display);font-weight:700;font-size:30px;color:var(--brand-bright);line-height:1.05;white-space:nowrap}
.payroll-next{text-align:right;font-size:12px;color:var(--ink-soft);font-weight:600}
.payroll-next span{display:block;margin-bottom:4px}
.payroll-next b{display:block;color:var(--ink);font-size:13px}
.payroll-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:0 2px 12px}
.payroll-metrics.two{grid-template-columns:1fr 1fr}
.pay-metric{border:1px solid var(--line);background:var(--card);padding:11px 12px}
.pay-metric span{display:block;font-size:11px;color:var(--ink-soft);font-weight:600}
.pay-metric b{display:block;font-size:17px;line-height:1.1;margin-top:5px}
.pay-metric.pair{display:flex;justify-content:space-between;gap:10px}
.pay-metric.pair>div{flex:1}
.pay-metric.pair b{font-size:16px;white-space:nowrap}
.payroll-debt{margin-top:8px;font-size:12px;font-weight:700;color:var(--gold);background:var(--gold-bg);border:1px solid var(--gold);border-radius:var(--r-sm);padding:5px 9px;display:inline-block}
.payroll-history{margin:18px 2px 12px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);overflow:hidden}
.payroll-history>summary{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:12px 14px;font-family:var(--font-display);font-weight:700;font-size:14px;list-style:none}
.payroll-history>summary::-webkit-details-marker{display:none}
.payroll-history>summary b{color:var(--brand-bright)}
.payroll-history[open]>summary{border-bottom:1px solid var(--line)}
.payroll-history .payroll-list{padding:10px 12px}
.fin-sub{margin-top:6px;font-size:12px;color:var(--ink-soft)}
.fin-ok{color:var(--green)}
.fin-bad{color:var(--danger)}
.fin-entry{border:1px solid var(--brand-line);background:var(--brand-tint);border-radius:var(--r-sm);padding:12px 14px;margin:0 2px 14px}
.fin-entry .row-title{margin-bottom:8px}
.fin-entry #finAmount{width:100%;border:1px solid var(--line-strong);background:var(--card);border-radius:var(--r-sm);padding:11px;color:var(--ink);font:inherit;font-size:18px;font-weight:700;text-align:center}
.fin-cats{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:9px}
.fin-cats button{border:1px solid var(--line-strong);background:var(--card);color:var(--ink);border-radius:var(--r-sm);padding:10px 6px;font:inherit;font-size:12.5px;font-weight:600;cursor:pointer}
.fin-cats button:active{background:var(--brand);color:var(--brand-ink);border-color:var(--brand)}
.fin-notice{margin-top:9px;font-size:12.5px;font-weight:700;color:var(--green);background:var(--ok-bg);border:1px solid var(--ok-line);border-radius:var(--r-sm);padding:8px 10px}
.fin-table{display:flex;flex-direction:column;gap:6px;margin:0 2px 12px}
.fin-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:8px;align-items:center;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);padding:9px 11px}
.fin-name{font-size:12.5px;color:var(--ink);font-weight:600;overflow-wrap:anywhere}
.fin-fact{text-align:right}
.fin-fact b{display:block;font-size:14px;color:var(--ink)}
.fin-fact i{font-style:normal;font-size:11px;color:var(--ink-soft)}
.fin-norm{text-align:right;font-size:11px;color:var(--ink-soft);font-weight:600}
.fin-norm i{display:block;font-style:normal;margin-top:2px}
.fin-row.over .fin-fact b{color:var(--danger)}
.fin-row.under .fin-fact b{color:var(--green)}
.fin-row.total{background:var(--card-2);border-color:var(--line-strong)}
.fin-row.total .fin-name{font-weight:700}
.fin-row.ebitda .fin-fact b{color:var(--brand-bright);font-size:15px}
.fin-fixed,.fin-recent,.fin-closings{margin:0 2px 12px;border:1px solid var(--line);background:var(--card);border-radius:var(--r-sm);overflow:hidden}
.fin-fixed>summary,.fin-recent>summary,.fin-closings>summary{cursor:pointer;padding:12px 14px;font-family:var(--font-display);font-weight:700;font-size:14px;list-style:none}
.fin-fixed>summary::-webkit-details-marker,.fin-recent>summary::-webkit-details-marker,.fin-closings>summary::-webkit-details-marker{display:none}
.fin-fixed form{margin:0;border:0;border-radius:0}
.fin-fixed-row{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px}
.fin-fixed-row span{font-size:13px;color:var(--ink-soft)}
.fin-fixed-row input{width:130px;border:1px solid var(--line-strong);background:var(--card-2);border-radius:var(--r-sm);padding:8px 10px;color:var(--ink);font:inherit;font-weight:600;text-align:right}
.fin-closings>div{padding:0 12px 12px}
.payroll-list{display:grid;gap:7px;margin:0 2px}
.payroll-row{display:flex;justify-content:space-between;align-items:center;gap:14px;border:1px solid var(--line);background:var(--card);padding:10px 12px}
.payroll-row b{display:block;font-size:15px}
.payroll-row small{display:block;color:var(--ink-soft);font-size:12px;margin-top:2px;font-weight:700}
.payroll-row i{font-style:normal;color:var(--ink-soft);font-size:11px;font-weight:600;text-transform:uppercase}
@media (min-width:900px){
  html,body{background:var(--paper)}
  .app-shell{display:block;padding:0;background:var(--paper)}
  .phone,.phone.wide,.phone.schedule-phone,.admin-phone{max-width:none;min-height:100vh;border:0;border-radius:0;box-shadow:none;overflow:visible}
  .screen{max-width:1180px;margin:0 auto;padding:28px 32px 42px}
  .service-page{min-height:100vh}
  .pin-wrap{min-height:calc(100vh - 90px);justify-content:center;padding-top:0}
  .phone.schedule-phone .schedule-screen{max-width:none;padding:22px 24px 34px}
  .shift-close-screen{max-width:860px;padding:24px 32px 38px}
  .payroll-screen{max-width:860px;padding:24px 32px 38px}
  .requisition-screen{max-width:1080px;padding:24px 32px 38px}
  .training-screen{max-width:1180px;padding:24px 32px 38px}
  .admin-screen{max-width:1280px;padding:24px 32px 38px}
  .backrow{margin-bottom:16px}
  .gridwrap{border-radius:var(--r-sm);box-shadow:0 1px 2px rgba(0,0,0,.3)}
  .schedule-grid th.emp{min-width:52px;width:52px}
  .schedule-grid td.cell{min-width:52px;width:52px}
  .moneySummary,.panel,.navcard,.scard,.roleTotals .rt,.admin-employee,.access-row,.field input,.field textarea,.field select,.payout-add input,.training-hero,.training-manager,.training-metrics>div,.training-person,.training-route,.training-chapters,.training-article,.training-chapter-btn,.training-attachment{border-radius:var(--r-sm)}
  .panel,.navcard,.scard,.moneySummary{box-shadow:0 1px 2px rgba(0,0,0,.3)}
  .nav{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}
  .navcard{min-height:104px}
  .admin-layout{grid-template-columns:320px minmax(0,1fr);gap:14px}
  .admin-employees{max-height:calc(100vh - 188px)}
  .admin-fields{grid-template-columns:minmax(220px,2fr) minmax(150px,1fr) minmax(130px,1fr) auto}
  .schedule-settings{grid-template-columns:minmax(170px,1.1fr) minmax(150px,1fr) minmax(120px,.7fr) minmax(140px,.8fr)}
  .cards{grid-template-columns:repeat(auto-fill,minmax(190px,1fr))}
  .iconbtn,.ghost,.btn{border-radius:var(--r-sm)}
}
@media (max-width:760px){
  .admin-layout{grid-template-columns:1fr}
  .admin-employees{max-height:260px}
  .admin-fields,.schedule-settings{grid-template-columns:1fr 1fr}
  .date-editor-grid{grid-template-columns:1fr}
  .payroll-hero{align-items:flex-start;flex-direction:column}
  .payroll-next{text-align:left}
  .payroll-metrics{grid-template-columns:1fr 1fr}
  .req-toolbar{grid-template-columns:1fr}
  .req-summary{grid-template-columns:1fr 1fr}
  .req-cart-groups{grid-template-columns:1fr}
  .req-free-grid{grid-template-columns:1fr 1fr}
  .req-free-name{grid-column:1/-1}
  .req-cart-line{grid-template-columns:1fr;align-items:flex-start}
  .req-cart-line .req-stepper{width:max-content}
  .task-metrics{grid-template-columns:1fr 1fr}
  .task-create-grid{grid-template-columns:1fr}
  .task-card{align-items:flex-start;flex-direction:column}
  .task-actions{width:100%;flex-wrap:wrap}
  .training-hero{grid-template-columns:1fr}
  .training-progress{text-align:left}
  .training-layout{grid-template-columns:1fr}
  .training-metrics{grid-template-columns:1fr 1fr}
  .training-manager-head,.training-article-head{flex-direction:column}
  .training-article-head .ghost{width:100%}
}
@media (max-width:370px){
  .keypad{grid-template-columns:repeat(3,64px);gap:12px}
  .key{height:58px}
  .nav{grid-template-columns:1fr}
  .two,.photo-grid,.extra-row{grid-template-columns:1fr}
  .editor-grid{grid-template-columns:1fr}
  .date-editor-grid{grid-template-columns:1fr}
  .payout-add{grid-template-columns:1fr}
  .req-summary{grid-template-columns:1fr}
  .req-free-grid{grid-template-columns:1fr}
  .req-item{grid-template-columns:auto 1fr}
  .req-item .req-stepper,.req-item .req-add,.req-item .req-item-controls{grid-column:2;justify-self:start}
  .training-metrics{grid-template-columns:1fr}
  .training-team{grid-template-columns:1fr}
  .training-person{grid-template-columns:1fr}
  .admin-layout{grid-template-columns:1fr}
  .admin-fields,.schedule-settings{grid-template-columns:1fr}
  .admin-tech{align-items:flex-start;flex-direction:column}
  .access-row{grid-template-columns:1fr auto auto}
}

/* утилиты */
.hub-gap{height:20px}
.mt-10{margin-top:10px}
.mt-12{margin-top:12px}
.w-100{width:100%}
.ta-left{text-align:left}
.hint-block{margin:0 2px 12px}
.hint-block-sm{margin:0 2px 8px}
