:root{
  --brand-primary:#2563EB;
  --bg-1:#070A12;
  --bg-2:#0B0F1A;
  --bg-3:#101624;
  --card-1:#111827;
  --card-2:#151C2E;
  --card-3:#1A2236;
  --text:#F8FAFC;
  --muted:#94A3B8;
  --faint:#64748B;
  --border:rgba(255,255,255,.08);
  --violet:#7C3AED;
  --violet-lite:#A855F7;
  --blue:#2563EB;
  --cyan:#38BDF8;
  --success:#22C55E;
  --warn:#FACC15;
  --danger:#EF4444;
}
*{box-sizing:border-box}
html,body{max-width:100%;height:100%;overflow:hidden}
body{
  margin:0;
  font-family:Inter,system-ui,sans-serif;
  color:var(--text);
  background:
    radial-gradient(1100px 500px at 20% -5%,rgba(124,58,237,.22),transparent 50%),
    radial-gradient(1000px 400px at 90% 0%,rgba(37,99,235,.2),transparent 45%),
    linear-gradient(170deg,var(--bg-1),var(--bg-2) 45%,var(--bg-3));
}
.app-shell{display:grid;grid-template-columns:280px minmax(0,1fr);height:calc(100vh - 56px);min-width:0;overflow:hidden}
.app-shell > .content{min-width:0;min-height:0}
.sidebar{
  position:sticky;top:0;height:calc(100vh - 56px);padding:20px 16px;border-right:1px solid var(--border);
  background:rgba(7,10,18,.9);backdrop-filter:blur(16px);min-width:0;overflow:hidden;
  display:flex;flex-direction:column;gap:10px
}
.brand{display:flex;justify-content:center;align-items:center;width:100%;margin-bottom:18px;padding:0 2px}
.brand-logo{
  width:100%;max-width:100%;height:auto;max-height:52px;object-fit:contain;
  filter:drop-shadow(0 6px 14px rgba(124,58,237,.45))
}
.brand-badge{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;font-weight:800;background:linear-gradient(135deg,var(--blue),var(--violet));box-shadow:0 10px 22px rgba(124,58,237,.45)}
.menu{display:grid;gap:7px;flex:1;min-height:0;overflow:auto;padding-right:6px}
.menu-item{
  border:1px solid transparent;color:var(--muted);background:transparent;
  border-radius:12px;padding:10px 11px;display:flex;gap:10px;align-items:center;cursor:pointer;text-align:left;font-size:13px
}
.menu-item:hover{background:rgba(255,255,255,.035);color:#fff}
.menu-item.active{
  color:#fff;background:linear-gradient(135deg,rgba(37,99,235,.35),rgba(124,58,237,.45));
  border-color:rgba(139,92,246,.35);box-shadow:0 0 22px rgba(124,58,237,.24)
}
.sidebar-user{margin-top:14px;padding:10px;border-radius:14px;display:flex;gap:10px;align-items:center}
.sidebar-user img{width:34px;height:34px;border-radius:10px}
.sidebar-user p{margin:0;font-weight:600}
.sidebar-user span{color:var(--muted);font-size:12px}

.content{
  padding:14px;min-width:0;min-height:0;flex:1;display:flex;flex-direction:column;overflow:hidden;
}
.content > .topbar{flex-shrink:0}
.content > #moduleContent{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
.glass,.card{background:linear-gradient(145deg,rgba(17,24,39,.95),rgba(15,23,42,.9));border:1px solid var(--border);box-shadow:0 20px 50px rgba(0,0,0,.35)}
.topbar{border-radius:18px;padding:14px 16px;display:flex;justify-content:space-between;gap:10px;align-items:center;flex-wrap:wrap}
.topbar h1{margin:0}
.muted{margin:2px 0 0;color:var(--muted)}
.topbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.field{border:1px solid var(--border);background:#0f172a;color:#fff;border-radius:12px;padding:10px 11px;width:100%}
.field.small{width:auto}
.btn{
  border:1px solid var(--border);background:#0f172a;color:#fff;border-radius:11px;padding:9px 13px;
  cursor:pointer;transition:.18s;font:inherit;text-decoration:none;display:inline-flex;align-items:center;justify-content:center
}
a.btn{color:inherit}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--violet));border:none}
.btn:hover{transform:scale(1.02)}
.btn.primary:hover{box-shadow:0 14px 30px rgba(124,58,237,.35)}
.btn.ghost:hover{background:rgba(255,255,255,.06)}
.topbar-actions a.btn.ghost{
  border-color:rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--muted)
}
.topbar-actions a.btn.ghost:hover{
  background:rgba(255,255,255,.08);color:var(--text);border-color:rgba(255,255,255,.16)
}
.module-section{margin-top:8px;display:grid;gap:8px;min-width:0;max-width:100%}
.toolbar{padding:12px 14px;border-radius:16px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar .field{max-width:260px}
.toolbar .spacer{flex:1}
.sidebar-toggle{display:none}

.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.card{padding:10px;border-radius:16px;min-width:0;max-width:100%}
.stat-card{padding:15px}
.stat-meta{display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:13px}
.stat-value{font-size:26px;font-weight:800;margin:10px 0 6px}
.stat-change{font-size:13px}
.up{color:var(--success)} .down{color:var(--danger)}
.panel-grid{display:grid;grid-template-columns:2fr 1fr;gap:12px}
.panel-grid.secondary{grid-template-columns:1fr 1fr}
.card-header{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px}
.card-header h3{margin:0;font-size:15px}

.line-chart{height:250px;border-radius:14px;background:
 linear-gradient(to top,rgba(124,58,237,.15),transparent 60%),
 repeating-linear-gradient(to right,rgba(255,255,255,.05) 0 1px,transparent 1px 60px),
 repeating-linear-gradient(to top,rgba(255,255,255,.03) 0 1px,transparent 1px 48px);
 position:relative;overflow:hidden
}
.line-chart::after{
  content:"";position:absolute;left:0;right:0;top:30%;bottom:0;
  background:linear-gradient(180deg,rgba(56,189,248,.0),rgba(56,189,248,.15));
  clip-path:polygon(0 60%,10% 50%,20% 56%,35% 40%,50% 48%,65% 26%,78% 34%,90% 20%,100% 28%,100% 100%,0 100%);
}
.chip-group{display:flex;gap:8px}
.chip{background:#0f172a;border:1px solid var(--border);color:var(--muted);padding:7px 10px;border-radius:999px}
.chip.active{background:rgba(124,58,237,.22);color:#fff}
.activity-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}
.activity-item{padding:10px;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--border)}
.activity-item b{display:block}

.kanban-wrap{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(190px,1fr);gap:10px;overflow-x:auto;padding-bottom:4px;max-width:100%}
.kanban-col{background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:14px;padding:8px;min-height:145px}
.kanban-col h4{margin:0 0 8px;font-size:13px;color:var(--muted)}
.kanban-item{padding:10px;border:1px solid var(--border);border-radius:11px;background:#0f172a;margin-bottom:8px;cursor:grab;overflow:hidden}
.kanban-item.dragging{opacity:.55}
.crm-card-title{cursor:pointer;margin:0 0 6px;font-weight:600}
.crm-card-title:hover{color:var(--accent)}
.customers-table .table-actions{white-space:nowrap;display:flex;gap:6px;flex-wrap:wrap}
.kanban-item p{
  margin:0 0 7px;font-weight:600;line-height:1.2;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}
.kanban-col.drop-target{outline:1px dashed rgba(124,58,237,.7);background:rgba(124,58,237,.07)}
.crm-kanban{min-width:0;max-width:100%;width:100%;cursor:grab;display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:8px;overflow:hidden}
.crm-kanban.is-panning{cursor:grabbing}
.task-kanban{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;overflow:hidden;min-width:0;max-width:100%;width:100%}

.offer-layout{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}
.offer-form{display:grid;gap:8px}
.offer-form label{font-size:13px;color:var(--muted);display:grid;gap:5px}
.offer-form textarea{min-height:68px;resize:vertical}
.offer-actions{display:flex;gap:8px;margin-top:3px}
.crm-card-actions{display:flex;justify-content:flex-end;margin-top:8px;gap:6px;flex-wrap:wrap}
.crm-card-actions .btn{padding:6px 9px;font-size:12px;line-height:1.1;white-space:nowrap}
.crm-toolbar strong{white-space:nowrap}
.crm-client-card .meta{margin-top:4px}
.crm-card-note{
  margin-top:6px;font-size:12px;color:var(--muted);line-height:1.25;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden
}
.crm-kanban-tools{display:flex;align-items:center;gap:8px}
.crm-modal-backdrop{
  position:fixed;inset:0;z-index:120;background:rgba(2,6,23,.72);
  display:grid;place-items:center;padding:16px
}
.crm-modal-wide{width:min(960px,98vw)}
.fin-inv-lines-title{margin:12px 0 6px;font-size:14px}
.fin-inv-lines-wrap{margin:8px 0;max-height:280px}
.fin-inv-lines-table{width:100%;font-size:13px}
.fin-inv-lines-table .field{width:100%;min-width:0;padding:6px 8px;font-size:13px}
.fin-inv-lines-table td{vertical-align:top;padding:6px 4px}
.fin-inv-stock-hint{display:block;margin-top:4px}
.fin-stock-archive-table td.danger{color:#f87171;font-weight:600}
.crm-modal{
  width:min(680px,96vw);max-height:92vh;overflow:auto;
  border-radius:16px;padding:16px;
  background:linear-gradient(145deg,rgba(17,24,39,.98),rgba(15,23,42,.96));
  border:1px solid var(--border);
  box-shadow:0 20px 50px rgba(0,0,0,.45)
}
.crm-modal h3{margin:0 0 10px}
.crm-notice{
  position:fixed;right:16px;bottom:16px;z-index:140;
  background:linear-gradient(135deg,rgba(37,99,235,.96),rgba(124,58,237,.96));
  color:#fff;padding:10px 12px;border-radius:10px;font-size:13px;
  box-shadow:0 12px 28px rgba(0,0,0,.35)
}
.pdf-preview{border-radius:16px;background:#f4f6fb;color:#0f172a;padding:14px;border:1px solid rgba(15,23,42,.12)}
.pdf-logo{margin:0;color:var(--violet);font-weight:800}
.pdf-preview h4{margin:8px 0 4px}
.pdf-preview .muted{color:#334155}
.pdf-block{padding:9px 0;border-bottom:1px solid rgba(15,23,42,.15)}
.pdf-block span{display:block;font-size:12px;color:#475569}

.calendar-week{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));gap:8px;overflow-x:auto}
.day-col{border:1px solid var(--border);border-radius:12px;padding:8px;background:rgba(255,255,255,.02)}
.day-col h5{margin:0 0 8px;color:var(--muted)}
.event{font-size:12px;background:rgba(37,99,235,.17);border:1px solid rgba(56,189,248,.4);padding:6px;border-radius:8px;margin-bottom:6px}
.event.warn{background:rgba(250,204,21,.15);border-color:rgba(250,204,21,.4)}

.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left;font-size:13px}
th{color:var(--muted);font-weight:600}
.badge{padding:3px 8px;border-radius:999px;font-size:12px;border:1px solid}
.badge.success{color:var(--success);border-color:rgba(34,197,94,.4);background:rgba(34,197,94,.12)}
.badge.warn{color:var(--warn);border-color:rgba(250,204,21,.4);background:rgba(250,204,21,.12)}
.badge.danger{color:var(--danger);border-color:rgba(239,68,68,.4);background:rgba(239,68,68,.12)}
.promise-list{margin:0;padding:0;list-style:none;display:grid;gap:8px}
.promise-item{padding:10px;border:1px solid var(--border);border-radius:12px;background:rgba(255,255,255,.02)}
.promise-item p{margin:0 0 7px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.empty{padding:28px;border-radius:14px;border:1px dashed rgba(168,85,247,.4);color:var(--muted);text-align:center;background:rgba(124,58,237,.08)}

.app-footer{
  height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 18px;
  border-top:1px solid rgba(139,92,246,.35);
  background:linear-gradient(90deg,#070a12,#14162d,#101624);
  color:#c4b5fd;font-size:12px
}
.footer-brand,.footer-center{font-weight:700;letter-spacing:.5px}
.footer-tags{display:flex;gap:14px;color:#93c5fd}

.login-page{min-height:100vh;display:grid;place-items:center;padding:18px}
.login-card{width:min(460px,96vw);border-radius:18px;padding:20px}
.login-brand{display:flex;justify-content:center;align-items:center;margin-bottom:16px}
.login-brand .brand-logo{width:auto;max-width:100%;max-height:56px;height:auto}
.login-card h1{margin:6px 0 2px}
.login-form{display:grid;gap:10px;margin-top:10px}
.login-form label{display:grid;gap:6px;color:var(--muted);font-size:14px}
.login-error{margin-top:10px;padding:9px 10px;border-radius:10px;border:1px solid rgba(239,68,68,.45);background:rgba(239,68,68,.16);color:#fecaca;font-size:13px}

@media (max-width:1366px){
  .crm-kanban{
    display:grid !important;
    grid-template-columns:repeat(8,minmax(0,1fr)) !important;
    overflow:hidden !important;
    padding-bottom:0;
  }
  .crm-kanban .kanban-col{min-width:0 !important}
}
@media (max-width:1200px){
  .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .panel-grid,.panel-grid.secondary,.split{grid-template-columns:1fr}
  .topbar-actions{justify-content:flex-start}
}
@media (max-width:1366px){
  .app-shell{grid-template-columns:240px minmax(0,1fr)}
}
@media (max-width:1100px){
  .app-shell{grid-template-columns:82px minmax(0,1fr)}
  .menu-item span,.sidebar-user div{display:none}
  .menu-item{justify-content:center}
  .topbar-actions .field.small{min-width:150px}
}
@media (max-width:760px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{
    position:fixed;left:0;top:0;bottom:0;z-index:40;width:min(88vw,320px);height:100vh;
    border-right:1px solid var(--border);border-bottom:none;transform:translateX(-100%);transition:transform .2s ease
  }
  body.sidebar-open .sidebar{transform:translateX(0)}
  .sidebar-toggle{display:inline-flex}
  .menu{grid-template-columns:repeat(2,minmax(0,1fr));max-height:none}
  .content{padding:12px}
  .stats-grid,.offer-layout{grid-template-columns:1fr}
  .crm-kanban{grid-template-columns:repeat(2,minmax(0,1fr)) !important;overflow:hidden !important}
  .crm-kanban .kanban-col{min-width:0 !important}
  .task-kanban{grid-template-columns:repeat(2,minmax(0,1fr))}
  .toolbar .field,.toolbar .field.small{max-width:none;width:100%}
  .topbar-actions{width:100%}
  .topbar-actions .field.small{width:100%}
  .app-footer{height:auto;flex-direction:column;gap:6px;padding:8px}
}

body.sidebar-collapsed .app-shell{grid-template-columns:82px minmax(0,1fr)}
body.sidebar-collapsed .menu-item span,
body.sidebar-collapsed .sidebar-user div{display:none}
body.sidebar-collapsed .menu-item{justify-content:center}

/* Scrollbar styling (dark, thin, purple — shared via .crm-scroll-purple) */
.crm-scroll-purple,
.sidebar,.menu,.kanban-wrap,.table-wrap,.calendar-week,#moduleContent{
  scrollbar-width:thin;
  scrollbar-color:rgba(124,58,237,.55) rgba(15,23,42,.55);
}
.crm-kanban{
  scrollbar-width:thin;
  scrollbar-color:rgba(124,58,237,.75) rgba(15,23,42,.6);
}
.crm-scroll-purple::-webkit-scrollbar,
.sidebar::-webkit-scrollbar,
.menu::-webkit-scrollbar,
.crm-kanban::-webkit-scrollbar,
.kanban-wrap::-webkit-scrollbar,
.table-wrap::-webkit-scrollbar,
.calendar-week::-webkit-scrollbar,
#moduleContent::-webkit-scrollbar{
  width:8px;
  height:8px;
}
.crm-scroll-purple::-webkit-scrollbar-track,
.sidebar::-webkit-scrollbar-track,
.menu::-webkit-scrollbar-track,
.crm-kanban::-webkit-scrollbar-track,
.kanban-wrap::-webkit-scrollbar-track,
.table-wrap::-webkit-scrollbar-track,
.calendar-week::-webkit-scrollbar-track,
#moduleContent::-webkit-scrollbar-track{
  background:rgba(15,23,42,.55);
  border-radius:999px;
}
.crm-scroll-purple::-webkit-scrollbar-thumb,
.sidebar::-webkit-scrollbar-thumb,
.menu::-webkit-scrollbar-thumb,
.crm-kanban::-webkit-scrollbar-thumb,
.kanban-wrap::-webkit-scrollbar-thumb,
.table-wrap::-webkit-scrollbar-thumb,
.calendar-week::-webkit-scrollbar-thumb,
#moduleContent::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,rgba(37,99,235,.9),rgba(124,58,237,.9));
  border-radius:999px;
  border:1px solid rgba(124,58,237,.25);
}
.crm-modal.crm-scroll-purple{max-height:92vh}
.crm-modal .admin-perm-grid,
.clientyx-module-grid{
  max-height:min(42vh,320px);
  overflow:auto;
  padding-right:4px;
}
.clientyx-onboarding{max-height:none}

@media (max-width:760px){
  .crm-kanban{grid-template-columns:1fr !important}
  .task-kanban{grid-template-columns:1fr}
}

/* Flatpickr – dark theme (CRM) */
.flatpickr-calendar{
  background:linear-gradient(145deg,#111827,#0f172a);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:0 20px 50px rgba(0,0,0,.45);
  color:var(--text);
  font-family:Inter,system-ui,sans-serif;
}
.flatpickr-months .flatpickr-month{
  background:transparent;color:var(--text);
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year{
  background:#0f172a;color:var(--text);border:1px solid var(--border);border-radius:8px;
}
.flatpickr-weekdays{background:transparent}
span.flatpickr-weekday{color:var(--muted)}
.flatpickr-day{color:var(--text);border-radius:8px}
.flatpickr-day:hover,
.flatpickr-day:focus{background:rgba(124,58,237,.2);border-color:rgba(124,58,237,.35)}
.flatpickr-day.today{border-color:rgba(56,189,248,.6)}
.flatpickr-day.selected,
.flatpickr-day.startRange,
.flatpickr-day.endRange{
  background:linear-gradient(135deg,var(--blue),var(--violet));
  border-color:transparent;color:#fff;
}
.flatpickr-day.flatpickr-disabled{color:var(--faint);opacity:.45}
.flatpickr-time .numInputWrapper span.arrowUp:after{border-bottom-color:var(--muted)}
.flatpickr-time .numInputWrapper span.arrowDown:after{border-top-color:var(--muted)}
.flatpickr-time input,
.flatpickr-time .flatpickr-am-pm{background:#0f172a;color:var(--text);border:1px solid var(--border)}
.flatpickr-months .flatpickr-prev-month:hover svg,
.flatpickr-months .flatpickr-next-month:hover svg{fill:var(--violet-lite)}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg{fill:var(--muted)}
input.flatpickr-input.flatpickr-alt-input,
input.flatpickr-input.flatpickr-mobile{
  background:#0f172a!important;
  color:#fff!important;
  border:1px solid var(--border)!important;
  border-radius:12px!important;
  padding:10px 11px!important;
  font-family:inherit!important;
}
input.flatpickr-input[readonly].flatpickr-alt-input{cursor:pointer}

/* Cenové ponuky */
.offers-panel-hidden{display:none!important}
.module-section.offers-module{min-height:0}
.offers-panel:not(.offers-panel-hidden){min-height:0}
.offers-split-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;margin-bottom:8px;flex-shrink:0}
.offers-head-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.offers-head-actions .field{max-width:280px;min-width:180px;width:100%}
.offer-preview-meta{margin:0 0 10px;line-height:1.45}
.offers-kanban-card{min-width:0;overflow:visible}
.offers-kanban-card .card-header{flex-wrap:wrap;gap:8px}
.offer-kanban-scroll{
  display:flex;flex-direction:row;flex-wrap:nowrap;gap:10px;
  overflow-x:auto;overflow-y:hidden;
  padding:4px 8px 14px 2px;margin-bottom:2px;
  max-width:100%;min-height:200px;
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
}
.offer-kanban-scroll .kanban-col{
  flex:0 0 auto;width:188px;min-width:168px;max-width:220px;scroll-snap-align:start;
}
.offer-kanban-scroll .kanban-col h4{
  white-space:normal;line-height:1.25;word-break:break-word;
}
.offer-editor-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-width:0;align-items:start}
@media (max-width:1100px){
  .offer-editor-split{grid-template-columns:1fr}
}
.offer-editor-form .offer-form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media (max-width:700px){
  .offer-editor-form .offer-form-grid-2{grid-template-columns:1fr}
}
.offer-lines-head{display:flex;justify-content:space-between;align-items:center;margin-top:12px;margin-bottom:6px}
.offer-lines-table-wrap{margin-top:4px;border-radius:12px;border:1px solid var(--border);overflow:auto}
.offer-lines-table{width:100%;border-collapse:collapse;font-size:13px}
.offer-lines-table th{padding:8px 6px;text-align:left;font-size:11px;color:var(--muted);background:rgba(255,255,255,.03)}
.offer-lines-table td{padding:4px 6px;vertical-align:middle}
.offer-lines-table .field{margin:0}
.small-btn{padding:6px 10px;font-size:12px}
.offer-totals-bar{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 14px;border-radius:14px;margin-top:12px}
.offer-preview-card{min-width:0}
.offer-preview-frame{min-height:240px;max-height:min(72vh,900px);overflow:auto;padding:14px;background:#0b0f1a;border-radius:14px;border:1px solid var(--border)}
.offer-preview-doc{font-size:12px;line-height:1.45}
.offer-preview-hdr{display:flex;align-items:center;gap:14px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.offer-preview-logo{height:42px;width:auto;filter:drop-shadow(0 4px 12px rgba(124,58,237,.35))}
.offer-preview-title{font-size:17px;font-weight:800;margin:0;background:linear-gradient(90deg,var(--cyan),var(--violet-lite));-webkit-background-clip:text;background-clip:text;color:transparent}
.offer-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.offer-preview-box{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:12px;padding:10px 12px}
.offer-preview-box h4{margin:0 0 8px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
.offer-preview-table{width:100%;border-collapse:collapse;font-size:11px;margin-top:6px}
.offer-preview-table th,.offer-preview-table td{border:1px solid var(--border);padding:6px 8px}
.offer-preview-table th{background:rgba(37,99,235,.12);color:var(--text)}
.offer-preview-table .num{text-align:right;font-variant-numeric:tabular-nums}
.offer-preview-totals{margin-top:12px;padding:12px;border-radius:12px;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(124,58,237,.15));border:1px solid rgba(124,58,237,.3)}
.offer-preview-totals p{display:flex;justify-content:space-between;margin:5px 0}
.offer-preview-totals .grand{font-weight:800;font-size:14px;margin-top:8px}
.danger-text{color:var(--danger)!important}
.offer-editor-top-actions{display:flex;gap:8px;flex-wrap:wrap}
.offer-number-readonly{display:block;margin-top:8px;font-weight:600}

.legal-strip{
  margin-top:8px;padding:8px 10px;border-radius:12px;font-size:12px;line-height:1.45;
  color:#e9d5ff;background:rgba(124,58,237,.18);border:1px solid rgba(168,85,247,.35);max-width:920px
}
.fin-upload-zone{border:2px dashed var(--border);border-radius:14px;padding:28px 16px;text-align:center;background:rgba(15,23,42,.35);margin:10px 0 12px;transition:border-color .2s,background .2s}
.fin-upload-zone.is-dragover{border-color:#67b7ff;background:rgba(103,183,255,.08)}
.fin-upload-card .btn{margin-top:4px}
.fin-sklad-lines-table .field{width:100%;min-width:0}
.fin-sklad-new-lbl{font-size:12px;color:var(--muted);white-space:nowrap}
.admin-perm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-top:10px}
.admin-perm-item{border:1px solid var(--border);border-radius:10px;padding:10px;background:rgba(15,23,42,.4)}
.admin-perm-item strong{display:block;font-size:13px;margin-bottom:6px}
.admin-perm-item label{display:inline-flex;align-items:center;gap:6px;font-size:12px;margin-right:10px;color:var(--muted)}
.crm-user-form .field{color-scheme:dark}
.crm-user-form .field:-webkit-autofill,
.crm-user-form .field:-webkit-autofill:hover,
.crm-user-form .field:-webkit-autofill:focus{
  -webkit-text-fill-color:#fff;
  -webkit-box-shadow:0 0 0 1000px #0f172a inset;
  caret-color:#fff;
}
.crm-toggle-chip{
  display:flex;align-items:center;gap:12px;margin:10px 0 4px;padding:12px 14px;
  border-radius:12px;border:1px solid var(--border);background:rgba(15,23,42,.45);cursor:pointer;
  transition:border-color .15s,background .15s;position:relative;user-select:none
}
.crm-toggle-chip:has(input:checked){border-color:rgba(103,183,255,.5);background:rgba(37,99,235,.1)}
.crm-toggle-chip input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.crm-toggle-track{
  flex:0 0 44px;width:44px;height:24px;border-radius:999px;background:rgba(51,65,85,.9);
  border:1px solid var(--border);position:relative;transition:background .15s,border-color .15s
}
.crm-toggle-track::after{
  content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:#94a3b8;transition:transform .15s,background .15s
}
.crm-toggle-chip:has(input:checked) .crm-toggle-track{background:rgba(37,99,235,.55);border-color:rgba(103,183,255,.45)}
.crm-toggle-chip:has(input:checked) .crm-toggle-track::after{transform:translateX(20px);background:#e2e8f0}
.crm-toggle-text{display:grid;gap:2px}
.crm-toggle-text strong{font-size:13px;color:#e2e8f0}
.erp-role-hint{margin:4px 0 8px;min-height:1.2em}
.erp-role-help{margin:8px 0 12px;border:1px solid var(--border);border-radius:12px;background:rgba(15,23,42,.35);overflow:hidden}
.erp-role-help summary{cursor:pointer;padding:10px 12px;font-size:13px;font-weight:600;color:#cbd5e1}
.erp-role-help-body{padding:0 12px 12px;display:grid;gap:10px;max-height:280px;overflow:auto}
.erp-role-help-row{padding:10px;border-radius:10px;border:1px solid rgba(51,65,85,.6);background:rgba(15,23,42,.35)}
.erp-role-help-row strong{display:block;font-size:13px;color:#e2e8f0;margin-bottom:4px}
.erp-role-perm-list{margin:6px 0 0;padding-left:18px;font-size:12px;color:var(--muted);line-height:1.45}
.fin-ocr-split{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:12px;margin-top:10px}
.fin-ocr-left iframe,.fin-ocr-left .fin-ocr-frame{width:100%;min-height:360px;border:1px solid var(--border);border-radius:12px;background:#0f172a}
.fin-json{font-size:12px;background:#0b1220;padding:10px;border-radius:12px;border:1px solid var(--border);max-height:420px;overflow:auto;white-space:pre-wrap}
.fin-ocr-right .ocr-field{display:grid;gap:4px;margin-bottom:8px;font-size:12px;color:var(--muted)}
.ocr-field-warn .field{border-color:rgba(250,204,21,.55);background:rgba(250,204,21,.08)}
.ocr-field-error .field{border-color:rgba(239,68,68,.55);background:rgba(239,68,68,.08)}
.ocr-field-ok .field{border-color:rgba(34,197,94,.45);background:rgba(34,197,94,.06)}
.fin-ocr-fields{max-height:420px;overflow:auto}
.ocr-conf-hint{font-size:11px;color:var(--muted);font-weight:400}
.ocr-meta-banner{margin:0 0 10px;padding:10px 12px;border-radius:12px;font-size:12px;line-height:1.5;background:rgba(103,183,255,.1);border:1px solid rgba(103,183,255,.28)}
.ocr-meta-banner.ocr-meta-error{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.35);color:#fecaca}
.ocr-meta-row{display:flex;flex-wrap:wrap;gap:10px 16px;align-items:center}
.ocr-meta-warn{color:#fde68a}
.fin-actions{white-space:nowrap}
.fin-transmission-hint{margin:0 0 8px;font-size:12px;line-height:1.45;max-width:920px}
.erp-setup-banner{margin:0 0 10px;padding:12px 14px;border-radius:14px;font-size:13px;line-height:1.5;color:#fde68a;background:rgba(250,204,21,.12);border:1px solid rgba(250,204,21,.35)}
.erp-setup-banner code{font-size:12px;color:#fef3c7}
.rpo-lookup-row{margin-bottom:12px;padding:12px 14px;border-radius:14px;border:1px solid var(--border)}
.rpo-lookup-inputs{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.rpo-lookup-inputs .field{flex:1;min-width:140px}
.rpo-lookup-hint{margin:8px 0 0}
.rpo-invoice-quick{margin-bottom:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border)}

.platform-bar{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  margin:10px 12px 0;padding:10px 14px;border-radius:14px;
  border:1px solid rgba(124,58,237,.35);
  background:linear-gradient(90deg,rgba(37,99,235,.12),rgba(124,58,237,.18));
}
.platform-bar-label{font-weight:800;letter-spacing:.06em;color:#c4b5fd}
.platform-bar-field{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.platform-bar-field .field{min-width:200px}
body:has(.platform-bar) .app-shell{min-height:calc(100vh - 56px)}
.clientyx-tenant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:12px}
.clientyx-tenant-card{padding:14px;border-radius:14px;border:1px solid var(--border);background:var(--card-2)}
.clientyx-tenant-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.clientyx-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.clientyx-form-grid .field{color-scheme:dark}
.clientyx-form-grid .field:-webkit-autofill,
.clientyx-form-grid .field:-webkit-autofill:hover,
.clientyx-form-grid .field:-webkit-autofill:focus{
  -webkit-text-fill-color:#fff;
  -webkit-box-shadow:0 0 0 1000px #0f172a inset;
  caret-color:#fff;
}
.clientyx-pack-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;grid-column:1/-1}
.clientyx-pack-chip{
  display:grid;gap:4px;padding:12px;border-radius:10px;border:1px solid var(--border);
  background:rgba(15,23,42,.4);cursor:pointer;transition:border-color .15s,background .15s
}
.clientyx-pack-chip:has(input:checked){border-color:rgba(103,183,255,.55);background:rgba(37,99,235,.12)}
.clientyx-pack-chip input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.clientyx-pack-chip strong{font-size:13px;color:#e2e8f0}
.clientyx-module-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:6px;
  margin-top:8px;padding:4px 2px
}
.clientyx-module-chip{
  display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:10px;
  border:1px solid var(--border);background:rgba(15,23,42,.35);cursor:pointer;font-size:12px
}
.clientyx-module-chip:has(input:checked){border-color:rgba(103,183,255,.5);background:rgba(37,99,235,.1)}
.clientyx-module-chip input{margin-top:2px;accent-color:var(--violet)}
@media (max-width:900px){.clientyx-form-grid{grid-template-columns:1fr}.clientyx-pack-grid{grid-template-columns:1fr}}

@media (max-width:760px){
  .fin-ocr-split{grid-template-columns:1fr}
}
