*{box-sizing:border-box}
body{font-family:Arial,sans-serif;margin:0;background:#f7f8fc;color:#1f2937}
.wrap{max-width:1180px;margin:0 auto;padding:16px}
.card{background:#fff;border:1px solid #e5e7eb;border-radius:14px;padding:14px;margin-bottom:12px;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.hero{background:linear-gradient(135deg,#f5f3ff,#eef2ff);border-color:#ddd6fe}
button{padding:9px 13px;cursor:pointer;border-radius:10px;border:1px solid #d1d5db;background:#fff}
button:hover{opacity:.95}
pre{white-space:pre-wrap}
.danger{background:#fee2e2;border:1px solid #ef4444}
.primary{background:#6d28d9;color:#fff;border:1px solid #6d28d9}
.line{display:flex;gap:8px;flex-wrap:wrap}
.acc{display:flex;gap:12px;align-items:center}
.acc img{width:46px;height:46px;border-radius:50%;object-fit:cover;background:#ddd}
input,select{padding:9px;border:1px solid #d1d5db;border-radius:10px;min-height:38px}
label{font-size:12px;color:#374151}
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.shell-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:12px}
.tabs{display:flex;gap:8px;flex-wrap:wrap}
.tab-btn{background:#eef2ff;border:1px solid #c7d2fe}
.tab-btn.active{background:#6d28d9;color:#fff;border-color:#6d28d9}
.hidden{display:none !important}
.hint{font-size:13px;color:#667085;margin-top:8px;line-height:1.35}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.hero-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}
.hero-copy{min-width:280px;flex:1 1 420px}
.hero-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.hero-actions button{white-space:nowrap}
.hello-title{font-size:20px;line-height:1.25;margin:0 0 6px 0;font-weight:700}
.hello-subtitle{font-size:13px;color:#667085;line-height:1.4;margin:0}
.topbar .line{justify-content:flex-end}
.topbar .line button{min-height:36px;padding:8px 12px}

/* Split Screen Login Styles */
.login-split{display:grid;grid-template-columns:1fr 1fr;min-height:500px;border-radius:16px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,0.1)}
.login-left{background:linear-gradient(135deg,#6d28d9 0%,#7c3aed 50%,#8b5cf6 100%);padding:48px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,0.1) 0%,transparent 70%);animation:pulse 15s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1);opacity:0.5}50%{transform:scale(1.1);opacity:0.8}}
.login-brand{color:#fff;position:relative;z-index:1}
.login-brand h2{font-size:32px;font-weight:700;margin:0 0 16px 0;line-height:1.2}
.login-brand p{font-size:16px;opacity:0.9;margin:0 0 32px 0;line-height:1.5}
.login-features{list-style:none;padding:0;margin:0}
.login-features li{color:#fff;opacity:0.85;padding:8px 0;display:flex;align-items:center;gap:10px;font-size:14px}
.login-features li::before{content:'✓';display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:rgba(255,255,255,0.2);border-radius:50%;font-size:12px;font-weight:bold}
.login-right{background:#fff;padding:48px;display:flex;flex-direction:column;justify-content:center}
.login-form-header{margin-bottom:32px}
.login-form-header h3{font-size:24px;font-weight:700;color:#111827;margin:0 0 8px 0}
.login-form-header p{font-size:14px;color:#6b7280;margin:0}
.login-form-actions{display:flex;flex-direction:column;gap:12px}
.login-form-actions .primary{width:100%;padding:14px 20px;font-size:16px;font-weight:600;justify-content:center;display:flex;align-items:center;transition:all 0.2s}
.login-form-actions .primary:hover{background:#5b21b6;transform:translateY(-1px);box-shadow:0 4px 12px rgba(109,40,217,0.3)}
.login-form-actions .secondary{width:100%;padding:14px 20px;font-size:16px;color:#4b5563;background:#f9fafb;border:1px solid #e5e7eb;justify-content:center;display:flex;align-items:center;transition:all 0.2s}
.login-form-actions .secondary:hover{background:#f3f4f6;border-color:#d1d5db}
.login-divider{text-align:center;margin:24px 0;position:relative}
.login-divider::before{content:'';position:absolute;left:0;right:0;top:50%;height:1px;background:#e5e7eb}
.login-divider span{position:relative;background:#fff;padding:0 16px;color:#6b7280;font-size:13px}
.login-help{text-align:center;margin-top:24px}
.login-help p{font-size:13px;color:#6b7280;margin:0 0 12px 0}
.muted{font-size:12px;color:#6b7280}
.kpi{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
.kpi .it{border:1px solid #e5e7eb;border-radius:10px;padding:10px}
.kpi .tt{font-size:12px;color:#6b7280}
.kpi .vv{font-size:20px;font-weight:700}
.kpi .delta{font-size:12px;margin-top:4px}
.kpi .delta.up{color:#16a34a}
.kpi .delta.down{color:#dc2626}
.kpi .delta.muted{color:#9ca3af}
.analytics-filters{margin:8px 0 12px}
.analytics-filters .filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end}
.analytics-filters label{display:flex;flex-direction:column;font-size:12px;color:#6b7280;min-width:140px}
.analytics-filters label > span{margin-bottom:4px}
.analytics-filters select,.analytics-filters input{padding:6px 8px;border:1px solid #e5e7eb;border-radius:8px;background:#fff;font-size:13px}
.analytics-filters .filter-actions{display:flex;gap:6px;align-self:flex-end}
.analytics-breadcrumbs{font-size:13px;color:#475569;margin-bottom:8px}
.analytics-breadcrumbs a{cursor:pointer;text-decoration:underline}
.analytics-funnel{display:flex;flex-direction:column;gap:6px;margin:12px 0}
.funnel-row{display:grid;grid-template-columns:140px 1fr 220px;gap:8px;align-items:center}
.funnel-label{font-size:13px;color:#1f2937}
.funnel-bar{position:relative;height:14px;background:#f1f5f9;border-radius:8px;overflow:hidden}
.funnel-bar-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#3b82f6,#9333ea)}
.funnel-meta{font-size:12px;color:#1f2937;text-align:right}
.analytics-chart-wrap{margin:12px 0}
.analytics-chart{border:1px solid #e5e7eb;border-radius:10px;padding:6px;background:#fff}
.chart-legend{display:flex;gap:12px;font-size:12px;color:#475569;margin-top:6px}
.chart-legend .lg{display:inline-flex;align-items:center;gap:6px}
.chart-legend .lg::before{content:"";display:inline-block;width:10px;height:10px;border-radius:2px}
.chart-legend .lg-blue::before{background:#2563eb}
.chart-legend .lg-green::before{background:#16a34a}
.chart-legend .lg-purple::before{background:#9333ea}
.analytics-tabs .tabs{display:flex;gap:6px;border-bottom:1px solid #e5e7eb;margin:12px 0 6px}
.analytics-tabs .tab{background:transparent;border:none;padding:6px 10px;font-size:13px;color:#475569;cursor:pointer;border-bottom:2px solid transparent}
.analytics-tabs .tab.is-active{color:#1f2937;border-bottom-color:#2563eb;font-weight:600}
.analytics-status-table{margin-top:12px}
.analytics-detail-wrap{margin-top:16px}
.analytics-detail-wrap .line{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}
.analytics-detail-wrap .line-right{display:flex;gap:6px;align-items:center}
.btn.ghost,button.ghost{background:transparent;border:1px solid #e5e7eb;color:#1f2937}
.detail-card{border:1px solid #e5e7eb;border-radius:10px;padding:12px;background:#fff;margin:6px 0}
.kv-list{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:13px}
.kv-list dt{color:#6b7280}
.kv-list dd{margin:0;color:#1f2937}
.status-chip{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}
.status-chip.ok{background:#ecfdf3;color:#15803d}
.status-chip.warn{background:#fffbeb;color:#a16207}
.status-chip.err{background:#fef2f2;color:#b91c1c}
.status-chip.muted{background:#f3f4f6;color:#6b7280}
table{width:100%;border-collapse:collapse}
th,td{border-bottom:1px solid #e5e7eb;padding:8px;font-size:13px;text-align:left}
th{background:#fafafa}
.table-wrap{overflow:auto;max-width:100%}
.table-wrap table{min-width:620px}
.compact-table th,.compact-table td{white-space:nowrap}
.log-box{max-height:320px;overflow:auto;background:#0f172a;color:#e2e8f0;border-radius:10px;padding:10px;font-size:12px;line-height:1.4}
.pill{padding:2px 8px;border-radius:999px;border:1px solid #ddd;font-size:12px;display:inline-block}
.pill.ok{background:#dcfce7;border-color:#86efac}
.pill.bad{background:#fee2e2;border-color:#fca5a5}
.pill.na{background:#f3f4f6;border-color:#d1d5db;color:#6b7280}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-bottom:8px}
.caps{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.acct-list{display:grid;gap:8px;margin-top:10px}
.acct-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:10px;border:1px solid #e5e7eb;border-radius:12px;background:#fff}
.acct-meta{display:flex;align-items:center;gap:10px;min-width:0}
.acct-meta img,.avatar-fallback{width:34px;height:34px;border-radius:50%;background:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:11px;color:#4b5563}
.acct-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}
.acct-remove-btn{padding:7px 10px}
.tg-open-help{margin-top:10px;padding:10px;border:1px dashed #c7d2fe;border-radius:12px;background:#f8fafc}
.tg-open-help .hint{margin-top:0}
/* =========================================
   CSS VARIABLES FOR MENU REDESIGN
   ========================================= */
:root {
  --bg-surface: #fff;
  --bg-light: #f8fafc;
  --border-color: #e5e7eb;
  --primary-color: #6d28d9;
  --text-primary: #1f2937;
  --text-secondary: #6b7280;
  --text-muted: #9ca3af;
  --shadow-sm: 0 1px 2px rgba(0,0,0,0.04);
  --shadow-lg: 0 10px 15px rgba(0,0,0,0.1);
  --border-radius-md: 8px;
  --border-radius-lg: 14px;
}
/* =========================================
   SIDEBAR MENU REDESIGN
   ========================================= */
.side-menu {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--bg-surface);
  border-radius: 0;
  box-shadow: none;
  border-right: 1px solid var(--border-color);
  padding: 0;
  overflow-y: auto;
  position: relative;
}
.side-menu-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border-color);
  background: var(--bg-surface);
  position: sticky;
  top: 0;
  z-index: 10;
}
.menu-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--text-primary);
  letter-spacing: -0.02em;
}
.menu-profile {
  padding: 24px;
  background: linear-gradient(to bottom, #f8fafc, #ffffff);
  border-bottom: 1px solid var(--border-color);
}
.side-menu .acc {
  display: flex;
  align-items: center;
  gap: 12px;
}
.side-menu .acc-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  background: #e2e8f0;
  border: 2px solid white;
  box-shadow: var(--shadow-sm);
}
.side-menu .acc-info {
  flex: 1;
  min-width: 0;
}
.side-menu .acc-name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--text-primary);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.side-menu .acc-user {
  font-size: 0.8rem;
  color: var(--text-secondary);
  margin-bottom: 4px;
}
.side-menu .acc-role {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--primary-color);
  background: #eff6ff;
  padding: 2px 8px;
  border-radius: 10px;
  display: inline-block;
}
.side-menu .caps {
  margin-top: 12px;
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.5;
  overflow: hidden;
  text-overflow: ellipsis;
}
.side-menu .menu-block {
  padding: 16px 12px;
}
.side-menu .menu-section-title {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin: 0 12px 12px 12px;
}
.side-menu .menu-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0;
  padding: 12px 16px;
  margin-bottom: 4px;
  background: transparent;
  border: none;
  border-radius: var(--border-radius-md);
  color: var(--text-secondary);
  font-size: 0.95rem;
  font-weight: 500;
  transition: all 0.2s ease;
  cursor: pointer;
  text-align: left;
}
.side-menu .menu-btn:hover {
  background: #f1f5f9;
  color: var(--text-primary);
}
.side-menu .menu-btn.active {
  background: #eff6ff;
  color: var(--primary-color);
  font-weight: 600;
}
.side-menu .btn-icon {
  margin-right: 12px;
  font-size: 1.1rem;
  width: 20px;
  text-align: center;
  display: inline-flex;
  justify-content: center;
}
.side-menu .btn-arrow {
  margin-left: auto;
  opacity: 0;
  transform: translateX(-5px);
  transition: all 0.2s ease;
  color: var(--text-muted);
}
.side-menu .menu-btn > span:not(.btn-icon) {
  display: inline-block;
  min-width: 0;
  white-space: nowrap;
}
.side-menu .menu-btn:hover .btn-arrow,
.tab-btn.active .btn-arrow {
  opacity: 1;
  transform: translateX(0);
}
.side-menu .side-menu-back, .side-menu .subnav-back {
  justify-content: flex-start;
  color: var(--text-secondary);
  font-size: 0.9rem;
  gap: 8px;
}
.side-menu .side-menu-back {
  display: none;
}
.side-menu .side-menu-back svg, .side-menu .subnav-back svg {
  width: 18px;
  height: 18px;
}
.side-menu .section-submenu {
  margin-left: 20px;
  padding-left: 12px;
  border-left: 2px solid #e2e8f0;
  margin-top: 4px;
  margin-bottom: 12px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.side-menu .submenu-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  background: transparent;
  border: none;
  border-radius: 6px;
  text-align: left;
  font-size: 0.85rem;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
}
.side-menu .submenu-btn > span:first-child {
  min-width: 0;
}
.side-menu .menu-counter {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.6em;
  padding: 0 0.45em;
  border-radius: 999px;
  font-size: inherit;
  font-weight: inherit;
  line-height: 1.2;
  color: #1d4ed8;
  background: #dbeafe;
  border: 1px solid #bfdbfe;
  margin-left: 8px;
  flex-shrink: 0;
  vertical-align: middle;
}
.side-menu .submenu-btn:hover {
  background: #f8fafc;
  color: var(--primary-color);
  padding-left: 20px;
}
.term-checks {
  gap: 10px;
}
.term-checks label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: #475569;
  background: #fff;
  border: 1px solid var(--eds-border);
  border-radius: 999px;
  padding: 6px 10px;
}
.term-checks input[type="checkbox"] {
  min-height: 0;
}
.side-menu .menu-subnav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: #f8fafc;
  border-radius: var(--border-radius-md);
  margin-bottom: 12px;
  border: 1px solid var(--border-color);
}
.side-menu .menu-subnav-title {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 0.9rem;
}
.side-menu .settings-block {
  margin-top: auto;
  border-top: 1px solid var(--border-color);
  background: #f8fafc;
}
.mobile-menu-toggle {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--primary-color);
  color: white;
  border: none;
  box-shadow: var(--shadow-lg);
  z-index: 998;
  align-items: center;
  justify-content: center;
}
.app-header{position:relative}
.header-greeting{font-size:18px;font-weight:700;line-height:1.25}
.settings-subtabs{display:flex;gap:6px;flex-wrap:wrap}
.side-menu .settings-subtabs .menu-btn{flex:1 1 calc(50% - 6px);text-align:center}
.settings-section{border:1px solid #e5e7eb;border-radius:10px;padding:8px;background:#fff}
.integrations-page-head{margin-bottom:10px}
.integrations-page-head-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.integrations-page-intro{margin:4px 0 0}
.integrations-toolbar{display:flex;align-items:flex-end;gap:12px;margin-bottom:12px;flex-wrap:wrap}
.integrations-hub{margin-bottom:4px}
.integration-hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.integration-hub-card{border:1px solid #e5e7eb;border-radius:12px;padding:16px;background:#f9fafb;display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.integration-hub-title{font-weight:600;font-size:16px;color:#111827}
.integration-hub-status{font-size:13px;line-height:1.35}
.integration-hub-status.is-ready{color:#059669}
.integration-hub-status.is-partial{color:#b45309}
.integration-hub-status.is-not_configured{color:#6b7280}
.integration-hub-status.is-disabled{color:#6b7280}
.integrations-intro{margin-bottom:8px}
.integrations-list{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.integrations-list--main{margin-top:0;max-width:720px}
#integrationsList.integration-detail-filter--onec .integration-card:not([data-integration-kind="onec"]),
#integrationsList.integration-detail-filter--digital_kassa .integration-card:not([data-integration-kind="digital_kassa"]){display:none!important}
.integration-card{border:1px solid #e5e7eb;border-radius:10px;padding:10px;background:#f9fafb}
.integration-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.integration-title{font-weight:600;font-size:14px;color:#111827}
.integration-status{font-size:12px}
.integration-status.is-ready{color:#059669}
.integration-status.is-partial{color:#b45309}
.integration-status.is-not_configured{color:#6b7280}
.integration-status.is-disabled{color:#6b7280}
.integration-form{display:flex;flex-direction:column;gap:6px;margin-top:8px;padding-top:8px;border-top:1px dashed #e5e7eb}
.integration-form label{font-size:12px;color:#374151}
.integration-form input,.integration-form select{padding:6px 8px;font-size:13px;border:1px solid #d1d5db;border-radius:8px;background:#fff}
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 0}
.switch-label{font-size:13px;color:#1f2937}
.switch-control{position:relative;display:inline-block;width:42px;height:24px}
.switch-control input{opacity:0;width:0;height:0}
.switch-slider{position:absolute;cursor:pointer;inset:0;background:#d1d5db;border-radius:999px;transition:.2s}
.switch-slider:before{position:absolute;content:'';height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s}
.switch-control input:checked + .switch-slider{background:#6d28d9}
.switch-control input:checked + .switch-slider:before{transform:translateX(18px)}
.workers-status{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;background:#e5e7eb;color:#374151}
.workers-status.is-ok{background:#ecfdf3;color:#047857}
.workers-status.is-error{background:#fef2f2;color:#b91c1c}
.workers-status.is-timeout{background:#fffbeb;color:#b45309}
.workers-status.is-none{background:#e5e7eb;color:#6b7280}
#workersMetricsBody td{font-size:12px;vertical-align:top}
#workersMetricsBody td.workers-error-cell{max-width:280px;color:#b91c1c;word-break:break-word}
.task-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.task-btn{background:#f8fafc}
.feedback{padding:10px;border-radius:10px;border:1px solid #e5e7eb;background:#f9fafb;font-size:13px;line-height:1.4;margin:8px 0}
.feedback.ok{background:#ecfdf3;border-color:#86efac}
.feedback.error{background:#fef2f2;border-color:#fca5a5}
.feedback.warn{background:#fffbeb;border-color:#fcd34d}
@media (max-width:1024px){.wrap{padding:12px} .grid{grid-template-columns:repeat(2,minmax(0,1fr))} .kpi{grid-template-columns:repeat(2,minmax(0,1fr))} .hello-title{font-size:18px} .hero-actions{justify-content:flex-start} .topbar .line{justify-content:flex-start}}
@media (min-width:769px) and (max-width:1024px){.shell-layout{grid-template-columns:1fr} .side-menu{position:fixed;left:0;top:0;bottom:0;width:min(72vw,340px);transform:translateX(-110%);transition:transform .22s ease;z-index:80;overflow:auto} body.menu-open .side-menu{transform:translateX(0)} .side-menu-head{display:flex} .content-col{transition:transform .22s ease} body.menu-open .content-col{transform:translateX(220px)} .mobile-menu-toggle{display:inline-flex;position:fixed;right:12px;top:12px;z-index:90}}
@media (max-width:768px){.shell-layout{grid-template-columns:1fr} .app-header{position:sticky;top:0;z-index:70} .mobile-menu-toggle{display:inline-flex} .side-menu{position:fixed;left:0;right:0;top:0;bottom:0;width:100vw;height:100dvh;transform:translateX(-110%);transition:transform .2s ease;z-index:85;overflow:auto;border-radius:0} body.menu-open .side-menu{transform:translateX(0)} body.menu-open{overflow:hidden} .side-menu-head{display:flex}}
@media (max-width:1024px){.side-menu .side-menu-back{display:inline-flex}}
@media (max-width:768px){.card{padding:12px} .grid{grid-template-columns:1fr} .kpi{grid-template-columns:1fr 1fr} .line button{flex:1 1 calc(50% - 8px)} .topbar{flex-direction:column} .app-header .topbar{flex-direction:row;align-items:center} .app-header .line{width:auto;justify-content:flex-end} .hero-head{flex-direction:column} .hero-copy{min-width:0;flex:1 1 auto} .hero-actions{width:100%} .hero-actions button{flex:1 1 calc(50% - 8px)} .acct-item{flex-direction:column;align-items:stretch} .acct-name{max-width:100%} .table-wrap table{min-width:560px} th,td{font-size:12px;padding:6px} .partners-table th:nth-child(3),.partners-table td:nth-child(3),.partners-table th:nth-child(6),.partners-table td:nth-child(6),.partners-table th:nth-child(7),.partners-table td:nth-child(7){display:none}}
@media (max-width:560px){.table-wrap table.mobile-stack{min-width:0;width:100%;border:0} .table-wrap table.mobile-stack thead{display:none} .table-wrap table.mobile-stack tbody,.table-wrap table.mobile-stack tr,.table-wrap table.mobile-stack td{display:block;width:100%} .table-wrap table.mobile-stack tr{border:1px solid #e5e7eb;border-radius:10px;padding:6px;margin-bottom:8px;background:#fff} .table-wrap table.mobile-stack td{border:0;padding:4px 8px} .table-wrap table.mobile-stack td::before{content:attr(data-label);display:block;font-size:11px;color:#6b7280;margin-bottom:2px}}
@media (max-width:480px){.wrap{padding:10px} .kpi{grid-template-columns:1fr} .line button{flex:1 1 100%} .tabs .tab-btn{width:100%}}

/* Split Screen Responsive */
@media (max-width:900px){.login-split{grid-template-columns:1fr} .login-left{padding:32px;min-height:200px} .login-brand h2{font-size:24px} .login-brand p{font-size:14px} .login-features{display:none}}
@media (max-width:560px){.login-split{border-radius:12px} .login-left{padding:24px} .login-right{padding:24px} .login-form-header h3{font-size:20px} .login-form-actions .primary,.login-form-actions .secondary{padding:12px 16px;font-size:14px}}

/* =========================================
   EDSOFA CLEAN BUSINESS (COMPAT LAYER)
   ========================================= */
:root {
  --eds-primary: #2563eb;
  --eds-primary-hover: #1d4ed8;
  --eds-bg-app: #f8fafc;
  --eds-bg-surface: #ffffff;
  --eds-text-main: #0f172a;
  --eds-text-muted: #64748b;
  --eds-border: #e2e8f0;
  --eds-radius: 12px;
  --eds-shadow-sm: 0 1px 2px 0 rgb(0 0 0 / 0.05);
  --eds-shadow-md: 0 4px 6px -1px rgb(0 0 0 / 0.1);
  --primary-color: var(--eds-primary);
  --bg-body: var(--eds-bg-app);
  --text-primary: var(--eds-text-main);
}

#appShell.app-shell {
  background: var(--eds-bg-app);
}

#appShell .layout-grid {
  display: flex;
  gap: 12px;
  min-height: calc(100vh - 220px);
}

#appShell .side-menu {
  width: 280px;
  border-right: 1px solid var(--eds-border);
  background: var(--eds-bg-surface);
  box-shadow: none;
  border-radius: var(--eds-radius);
  flex-shrink: 0;
  overflow-y: auto;
  z-index: 95;
}

#appShell .main-content {
  flex: 1;
  min-width: 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

#appShell .app-header .topbar {
  align-items: center;
}

#appShell .card.work-card {
  padding: 0 14px 14px;
}

#appShell .card.work-card > h3 {
  margin: 0;
  min-height: 52px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--eds-border);
}

#appShell .app-header .line {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

#appShell .content-scroll {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  padding: 0 0 20px;
}

#appShell .side-menu-head {
  padding: 0 16px;
  min-height: 52px;
}

#appShell .menu-profile {
  padding-top: 16px;
}

#appShell .apps-create-flow {
  display: grid;
  gap: 10px;
}

#appShell .apps-step {
  padding: 12px;
  border: 1px solid var(--eds-border);
  border-radius: 10px;
  background: #fcfdff;
}

#appShell .apps-step-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

#appShell .apps-step label {
  display: block;
  margin-bottom: 6px;
}

#appShell .apps-static-value {
  padding: 10px 12px;
  border: 1px solid var(--eds-border);
  border-radius: 10px;
  background: #fff;
  font-weight: 600;
}

#appShell .apps-create-result {
  margin-top: 8px;
  padding: 12px;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
  background: #eff6ff;
}

#appShell .apps-result-title {
  font-weight: 700;
  color: #1d4ed8;
}

#appShell .apps-result-meta {
  margin-top: 6px;
  font-size: 13px;
  color: var(--eds-text-main);
}

#appShell tr.links-row-highlight {
  background: #fffbeb;
  box-shadow: inset 0 0 0 2px #f59e0b;
}

#appShell .menu-btn {
  position: relative;
}

#appShell .menu-btn.active {
  background: #eff6ff;
  color: var(--eds-primary);
  font-weight: 600;
}

#appShell .menu-btn.active::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 24px;
  background: var(--eds-primary);
  border-radius: 0 4px 4px 0;
}

#appShell .btn-arrow {
  transition: transform 0.2s ease, opacity 0.2s ease;
}

#appShell .menu-btn[aria-expanded="true"] .btn-arrow {
  transform: rotate(90deg);
  opacity: 1;
}

#appShell .menu-overlay {
  position: fixed;
  inset: 0;
  background: rgb(15 23 42 / 0.35);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
  z-index: 90;
}

#appShell .menu-overlay.active {
  opacity: 1;
  pointer-events: auto;
}

#appShell .table-wrap table,
#appShell .data-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--eds-bg-surface);
}

@media (max-width: 768px) {
  #appShell .layout-grid {
    min-height: 0;
  }

  #appShell .mobile-menu-toggle {
    display: inline-flex;
    position: static;
    top: auto;
    right: auto;
    left: auto;
    bottom: auto;
    z-index: auto;
    width: auto;
    height: 38px;
    border-radius: 10px;
    padding: 0 12px;
    font-size: 13px;
    font-weight: 600;
    box-shadow: var(--eds-shadow-sm);
    margin: 0;
  }

  #appShell .side-menu {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: min(82vw, 320px);
    max-width: 320px;
    transform: translateX(-100%);
    transition: transform 0.25s ease;
    box-shadow: var(--eds-shadow-md);
  }

  #appShell .side-menu.open {
    transform: translateX(0);
  }

  #appShell .content-scroll {
    padding-top: 16px;
  }

  #appShell .apps-step-row {
    grid-template-columns: 1fr;
  }

  #appShell .table-wrap table,
  #appShell .data-table,
  #appShell .table-wrap tbody,
  #appShell .table-wrap tr,
  #appShell .table-wrap td {
    display: block;
    width: 100%;
  }

  #appShell .table-wrap thead {
    display: none;
  }

  #appShell .table-wrap tr {
    margin-bottom: 10px;
    padding: 10px;
    border: 1px solid var(--eds-border);
    border-radius: 10px;
    box-shadow: var(--eds-shadow-sm);
    background: var(--eds-bg-surface);
  }

  #appShell .table-wrap td {
    padding: 8px 8px 8px 44%;
    border: 0;
    border-bottom: 1px solid #f1f5f9;
    position: relative;
    text-align: right;
    min-height: 32px;
  }

  #appShell .table-wrap td:last-child {
    border-bottom: 0;
  }

  #appShell .table-wrap td[data-label]::before {
    content: attr(data-label);
    position: absolute;
    left: 8px;
    top: 8px;
    font-size: 12px;
    color: var(--eds-text-muted);
    font-weight: 600;
    text-align: left;
    max-width: 42%;
  }
}

@media (min-width: 769px) {
  #appShell .side-menu {
    position: sticky;
    top: 0;
    align-self: flex-start;
    max-height: 100vh;
  }
}

/* QR-login modals */
.pwa-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 10050;
  background: rgba(15, 23, 42, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
  overflow-y: auto;
}
.pwa-modal-panel {
  position: relative;
  background: #fff;
  border-radius: 16px;
  padding: 20px 20px 22px;
  max-width: 420px;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.18);
}
.pwa-modal-panel--wide {
  max-width: 520px;
}
.pwa-modal-title {
  margin: 0 0 12px 0;
  font-size: 20px;
}
.pwa-modal-close {
  position: absolute;
  top: 10px;
  right: 12px;
  border: none;
  background: transparent;
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
  color: #64748b;
}
.pwa-modal-body {
  margin-top: 8px;
  min-width: 0;
}
.pwa-qr-steps {
  margin: 0;
  padding-left: 20px;
  line-height: 1.45;
  font-size: 14px;
  color: #374151;
}
.pwa-qr-steps li {
  margin-bottom: 8px;
}
.pwa-qr-canvas-wrap {
  display: flex;
  justify-content: center;
  margin: 16px 0;
}
.pwa-otp-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: stretch;
  margin-top: 12px;
  min-width: 0;
}
.pwa-otp-row input {
  flex: 1 1 auto;
  min-width: 0;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
  font-size: 20px;
  letter-spacing: 0.12em;
  text-align: center;
}
.pwa-otp-row .primary {
  flex: 0 0 auto;
  min-width: 0;
}
@media (max-width: 520px) {
  .pwa-otp-row {
    flex-direction: column;
    align-items: stretch;
  }
  .pwa-otp-row .primary {
    width: 100%;
  }
}
.pwa-qr-url-input {
  flex: 1 1 180px;
  min-width: 0;
  font-size: 13px;
  padding: 10px 12px;
  border: 1px solid var(--eds-border, #e2e8f0);
  border-radius: 10px;
  background: #f8fafc;
  color: #0f172a;
}
.pwa-qr-fallback-row,
.pwa-qr-paste-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
  margin-top: 10px;
}
.pwa-qr-fallback-actions {
  margin-top: 12px;
  justify-content: flex-start;
}
.pwa-qr-paste-title {
  margin-top: 16px;
  margin-bottom: 0;
}
