@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #f4f6f8;--surface: #ffffff;--border: #e0e5ec;--border-soft: #edf1f5;--text: #111827;--text-dim: #5f6b7a;--text-faint: #94a1b0;--accent: #16a34a;--accent-hover: #15803d;--accent-soft: #dcfce7;--danger: #dc2626;--danger-soft: #fee2e2;--blue: #3b82f6;--blue-soft: #dbeafe;--amber: #f59e0b;--amber-soft: #fef3c7;--violet: #8b5cf6;--violet-soft: #ede9fe;--cyan: #06b6d4;--cyan-soft: #cffafe;--rose: #f43f5e;--rose-soft: #ffe4e6;--emerald: #10b981;--emerald-soft: #d1fae5;--font: Inter, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", sans-serif;--fs-12: 12px;--fs-13: 13px;--fs-14: 14px;--fs-16: 16px;--fs-20: 20px;--fs-28: 28px;--r-6: 6px;--r-10: 10px;--r-14: 14px;--r-20: 20px;--shadow-1: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-2: 0 4px 16px -4px rgba(0,0,0,.1), 0 2px 6px -2px rgba(0,0,0,.06);--shadow-3: 0 10px 40px -8px rgba(0,0,0,.12), 0 4px 12px -4px rgba(0,0,0,.08);--sidebar-w: 240px;--transition: .18s cubic-bezier(.4,0,.2,1);--tbl-head-bg: #f8fafc;--tbl-even-bg: #fafbfd;--tbl-hover-bg: #f0f7ff}[data-theme=dark]{--bg: #0c1220;--surface: #111827;--border: #1e293b;--border-soft: #1a2332;--text: #f1f5f9;--text-dim: #94a3b8;--text-faint: #64748b;--accent: #4ade80;--accent-hover: #22c55e;--accent-soft: #052e16;--danger: #f87171;--danger-soft: #450a0a;--blue: #60a5fa;--blue-soft: #1e3a5f;--amber: #fbbf24;--amber-soft: #451a03;--violet: #a78bfa;--violet-soft: #2e1065;--cyan: #22d3ee;--cyan-soft: #083344;--rose: #fb7185;--rose-soft: #4c0519;--emerald: #34d399;--emerald-soft: #022c22;--shadow-1: 0 1px 3px rgba(0,0,0,.2), 0 1px 2px rgba(0,0,0,.15);--shadow-2: 0 4px 16px -4px rgba(0,0,0,.3), 0 2px 6px -2px rgba(0,0,0,.2);--shadow-3: 0 10px 40px -8px rgba(0,0,0,.4), 0 4px 12px -4px rgba(0,0,0,.25);--tbl-head-bg: #0f172a;--tbl-even-bg: #0e1525;--tbl-hover-bg: #162032}*{box-sizing:border-box}html{scroll-behavior:smooth}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}::selection{background:var(--accent-soft);color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}*{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-w);background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;transition:width .2s ease;overflow:hidden}.sidebar.collapsed{width:64px}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:12px 12px 8px;border-bottom:1px solid var(--border);min-height:56px}.sidebar.collapsed .sidebar-header{padding:12px 8px 8px;justify-content:center}.brand{display:flex;align-items:center;gap:10px}.brand-title{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden}.sidebar.collapsed .brand-title{display:none}.collapse-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;padding:6px;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.collapse-btn:hover{background:var(--border-soft);color:var(--text)}.sidebar.collapsed .collapse-btn{position:absolute;right:4px;top:14px}.side-nav{display:flex;flex-direction:column;flex:1;overflow-y:auto;overflow-x:hidden;padding:8px}.sidebar.collapsed .side-nav{padding:8px 6px}.nav-group{margin-bottom:4px}.nav-group-title{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-faint);padding:12px 10px 6px;white-space:nowrap}.nav-divider{height:1px;background:var(--border);margin:8px 6px}.side-nav a{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text-dim);padding:8px 10px;border-radius:8px;font-weight:500;font-size:13px;transition:var(--transition);white-space:nowrap;position:relative}.sidebar.collapsed .side-nav a{padding:10px;justify-content:center}.side-nav a .icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.side-nav a .label{overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .side-nav a .label{display:none}.side-nav a:hover{background:var(--border-soft);color:var(--text)}.side-nav a:hover .icon{transform:scale(1.12)}.side-nav a .icon{transition:transform .15s ease}.side-nav a.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px -2px #16a34a59;position:relative}.side-nav a.active:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 3px 3px 0;background:#fff;opacity:.7}.sidebar-footer{padding:8px;border-top:1px solid var(--border)}.sidebar.collapsed .sidebar-footer{padding:8px 6px}.profile-mini{display:flex;align-items:center;gap:10px;width:100%;padding:8px 10px;border:none;background:var(--border-soft);border-radius:8px;cursor:pointer;transition:var(--transition);text-align:left}.sidebar.collapsed .profile-mini{padding:8px;justify-content:center}.profile-mini:hover{filter:brightness(1.05)}.profile-mini .avatar{width:28px;height:28px;border-radius:6px;background:linear-gradient(135deg,var(--accent),#2ea79d);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.profile-mini .username{font-size:13px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.profile-mini .chevron{color:var(--text-dim);font-size:16px}.sidebar.collapsed .profile-mini .username,.sidebar.collapsed .profile-mini .chevron{display:none}.sidebar.collapsed .side-nav a:after{content:attr(title);position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--surface);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:100;box-shadow:var(--shadow-1);pointer-events:none}.sidebar.collapsed .side-nav a:hover:after{opacity:1;visibility:visible}.sidebar.collapsed .profile-mini:after{content:"Профиль";position:absolute;left:calc(100% + 8px);top:50%;transform:translateY(-50%);background:var(--surface);border:1px solid var(--border);color:var(--text);padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .15s,visibility .15s;z-index:100;box-shadow:var(--shadow-1);pointer-events:none}.sidebar.collapsed .profile-mini{position:relative}.sidebar.collapsed .profile-mini:hover:after{opacity:1;visibility:visible}.topbar{position:sticky;top:0;z-index:50;display:flex;gap:12px;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);background:var(--surface)}.topbar .search{flex:1;display:flex;align-items:center;gap:8px}.topbar input[type=search]{width:100%;background:#ffffff05;border:1px solid var(--border);padding:10px 12px;border-radius:12px;color:var(--text);font-size:var(--fs-14);transition:var(--transition)}.topbar .search{position:relative}.topbar .search .clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--text-dim);font-size:16px;line-height:1;cursor:pointer;padding:4px;border-radius:8px}.topbar .search .clear:hover{background:var(--tbl-head-bg);color:var(--text)}.topbar input[type=search]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff1}.topbar .actions{display:flex;gap:8px}.hamburger{display:none}.main-area{flex:1;display:flex;flex-direction:column;min-width:0}.mobile-topbar{display:none}.offline-banner{display:flex;align-items:center;gap:8px;justify-content:center;padding:8px 16px;background:#fbbf24;color:#78350f;font-size:13px;font-weight:500;line-height:1.4;position:sticky;top:0;z-index:100}[data-theme=dark] .offline-banner{background:#92400e;color:#fef3c7}.content{width:100%;max-width:1700px;margin:0 auto;padding:24px clamp(16px,3vw,48px) 48px;animation:page-enter .25s ease-out}@keyframes page-enter{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.panel{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:20px 22px 24px;box-shadow:var(--shadow-1);transition:box-shadow .2s ease,transform .2s ease}.panel:hover{box-shadow:var(--shadow-2)}.panel h2{margin:0 0 12px;font-size:12px;letter-spacing:.6px;color:var(--text-dim);text-transform:uppercase}.panel-header h2{margin:0}.panel h3{margin:0 0 10px;font-size:14px;letter-spacing:.4px;color:var(--text-dim)}.panel input[type=text],.panel input[type=date],.panel input[type=number],.panel input[type=search],.panel select,.panel textarea{background:#ffffff05;border:1px solid var(--border);color:var(--text);padding:10px 12px;font-size:var(--fs-14);border-radius:10px;outline:none;transition:var(--transition)}.panel input:focus,.panel select:focus,.panel textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff1}select option{color:var(--text);background:var(--surface)}[data-theme=dark] select option{color:#e5e7eb;background:#0b1223}.panel-header{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.panel-actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.toolbar select,.toolbar input[type=date],.toolbar input[type=number]{min-width:160px}.hangars-page-grid{display:grid;grid-template-columns:260px 1fr;gap:16px}.hangars-list{margin-top:12px;display:grid;gap:6px}.hangar-item{padding:8px 10px;border-radius:8px;border:1px solid transparent;background:transparent;display:grid;grid-template-columns:1fr auto;align-items:center;gap:8px}.hangar-item.selected{background:var(--border-soft);border-color:var(--border)}.hangar-item-main{min-width:0;cursor:pointer}.hangar-item-name{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hangar-item-meta{font-size:12px;color:var(--text-dim)}.sensors-block{margin-top:16px}.sensors-title{margin:8px 0 10px}.sensor-list{display:grid;gap:8px}.sensor-empty{font-size:12px;color:var(--text-dim);border:1px dashed var(--border);border-radius:10px;padding:10px 12px}.sensor-card{border:1px solid var(--border);border-radius:10px;padding:10px 12px;background:var(--surface);display:grid;gap:5px;overflow:hidden;min-width:0}.sensor-name-row{display:flex;align-items:center;gap:7px;min-width:0;overflow:hidden}.sensor-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1 0;color:var(--text)}.sensor-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sensor-dot--online{background:#22c55e;box-shadow:0 0 0 2px #22c55e40;animation:sensor-pulse 2s ease-in-out infinite}.sensor-dot--stale{background:#f59e0b}.sensor-dot--offline{background:var(--text-dim);opacity:.5}@keyframes sensor-pulse{0%,to{box-shadow:0 0 0 2px #22c55e40}50%{box-shadow:0 0 0 4px #22c55e1a}}.sensor-value-row{display:flex;align-items:baseline;gap:8px;min-width:0}.sensor-value{font-size:22px;font-weight:700;line-height:1;flex-shrink:0}.sensor-value.muted{color:var(--text-dim)}.sensor-value.ok{color:var(--accent)}.sensor-value.bad{color:var(--danger)}.sensor-norm{font-size:11px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.sensor-topic{font-size:10px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;opacity:.8}.sensor-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;margin-top:2px}.sensor-time{font-size:11px;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1 0;min-width:0}.sensor-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.sensor-icon-btn{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);color:inherit;cursor:pointer}.sensor-icon-btn:hover{background:var(--border-soft)}.sensor-icon-btn.danger{border-color:var(--danger);color:var(--danger);background:transparent}.sensor-text-btn{height:26px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);color:inherit;cursor:pointer;padding:0 8px;font-size:11px;font-weight:600}.sensor-text-btn:hover{background:var(--border-soft)}.sensor-ingest-popover-wrap{position:absolute;right:0;top:30px;z-index:20}.sensor-ingest-popover{background:#fff;color:#111;border:1px solid var(--border);border-radius:8px;padding:8px;box-shadow:0 6px 18px #0000002e,0 2px 6px #0000001f}.sensor-ingest-row{display:flex;align-items:center;gap:6px}.sensor-ingest-input{width:84px;padding:6px 8px;border:1px solid var(--border);border-radius:6px}.hangar-main-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px}.hangar-main-title{margin:0;max-width:72%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-soft)}.page-header h1{margin:0;font-size:var(--fs-20);font-weight:700}.page-header .page-actions{display:flex;align-items:center;gap:8px}.btn{--bg: var(--accent);--bg-hover: var(--accent-hover);background:var(--bg);border:1px solid var(--bg);color:#fff;font-weight:600;font-size:var(--fs-14);padding:10px 16px;border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;gap:8px;line-height:1;transition:var(--transition);box-shadow:0 1px 2px #0000001f,0 2px 4px -2px #0000001f}.btn:hover{background:var(--bg-hover);border-color:var(--bg-hover)}.btn:active{transform:translateY(1px) scale(.97);box-shadow:0 0 #0000}.btn.secondary{--bg:#eef2f6;--bg-hover:#e6ebf2;color:var(--text);border-color:var(--border)}.btn.danger{--bg: var(--danger);--bg-hover:#bf1f1f}.btn.small{padding:6px 12px;font-size:var(--fs-12)}.btn.inline-delete{padding:5px 10px;font-size:12px;font-weight:500;border-radius:8px}.btn:focus{outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.btn[disabled],.btn:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;filter:grayscale(10%)}.btn .spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.6);border-top-color:#fff;border-radius:50%;display:inline-block;animation:spin 1s linear infinite;margin-right:8px}@keyframes spin{to{transform:rotate(360deg)}}.tab-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--border-soft);border:1px solid var(--border);color:var(--text-dim);padding:8px 12px;border-radius:10px;font:600 13px var(--font);cursor:pointer;transition:var(--transition)}.tab-btn:hover{filter:brightness(1.05);color:var(--text)}.tab-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 10px -4px #0006}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;background:#eef3f7;border:1px solid var(--border);color:var(--text-dim);font-size:11px;border-radius:999px}.badge.accent{background:var(--accent-soft);border-color:var(--accent-soft);color:var(--accent)}form.modern-form{display:flex;flex-direction:column;gap:16px}form.modern-form label{display:flex;gap:6px;flex-direction:column;font-size:11px;letter-spacing:.5px;color:var(--text-dim);text-transform:uppercase;font-weight:600}form.modern-form label.role-card{flex-direction:row;text-transform:none;font-size:inherit;letter-spacing:0;color:inherit;font-weight:400;align-items:center;gap:14px}form.modern-form input,form.modern-form select,form.modern-form textarea{background:#ffffff05;border:1px solid var(--border);color:var(--text);padding:12px 14px;font-size:var(--fs-14);border-radius:12px;outline:none;transition:var(--transition)}form.modern-form textarea{min-height:120px;resize:vertical}form.modern-form input:focus,form.modern-form select:focus,form.modern-form textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff1}input:focus-visible,select:focus-visible,textarea:focus-visible,button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}form.modern-form .inline{display:flex;gap:16px}form.modern-form .inline>*{flex:1}.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.table-wrap{overflow-x:auto;border-radius:12px;border:1px solid var(--border)}table.modern{width:100%;border-collapse:collapse;font-size:var(--fs-13)}table.modern thead th{text-align:left;padding:10px 14px;font-weight:600;color:var(--text-dim);font-size:11px;letter-spacing:.6px;text-transform:uppercase;border-bottom:2px solid var(--border);background:var(--tbl-head-bg);position:sticky;top:0;z-index:2}table.modern thead th:first-child{border-radius:12px 0 0}table.modern thead th:last-child{border-radius:0 12px 0 0}table.modern thead th[data-sort]{cursor:pointer;-webkit-user-select:none;user-select:none}table.modern thead th[data-sort]:hover{color:var(--text);background:var(--border-soft)}table.modern thead th .sort-icon{display:inline-block;margin-left:4px;font-size:10px;opacity:.5;transition:opacity .15s}table.modern thead th[data-sort]:hover .sort-icon{opacity:1}table.modern tbody td{padding:9px 14px;border-bottom:1px solid var(--border-soft);color:var(--text)}table.modern tbody tr{background:var(--surface);transition:background .15s,box-shadow .15s}table.modern tbody tr:nth-child(2n){background:var(--tbl-even-bg)}table.modern tbody tr:hover{background:var(--tbl-hover-bg);box-shadow:0 1px 4px #0000000f}table.modern tbody tr:last-child td:first-child{border-radius:0 0 0 12px}table.modern tbody tr:last-child td:last-child{border-radius:0 0 12px}[data-theme=dark] table.modern thead th{color:#a7b4c7}[data-theme=dark] table.modern tbody td{color:#e5e7eb}.profile-trigger{display:flex;align-items:center;gap:10px;width:100%;background:var(--border-soft);border:1px solid var(--border);padding:10px 12px;border-radius:12px;cursor:pointer;font:600 13px var(--font);color:var(--text);text-align:left;transition:var(--transition);position:relative;min-height:48px}.profile-trigger:hover{filter:brightness(1.05)}.profile-trigger .avatar{flex:0 0 30px;width:30px;height:30px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#2ea79d);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.profile-trigger span:nth-child(2){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-trigger .caret{margin-left:auto;font-size:14px;color:var(--text-dim)}.profile-hero{display:flex;align-items:center;gap:16px;padding:28px 28px 20px;border-bottom:1px solid var(--border)}.profile-avatar-lg{width:56px;height:56px;border-radius:var(--r-14);flex-shrink:0;background:linear-gradient(135deg,var(--accent),#06b6d4);color:#fff;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px -2px #16a34a4d}.profile-hero-info{display:flex;flex-direction:column;gap:6px;min-width:0}.profile-hero-name{font-size:18px;font-weight:700;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-hero-meta{display:flex;gap:8px;flex-wrap:wrap}.profile-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;background:var(--accent-soft);color:var(--accent);border:1px solid transparent}.profile-badge.secondary{background:var(--blue-soft);color:var(--blue)}.profile-tabs{display:flex;gap:0;padding:0 28px;border-bottom:1px solid var(--border)}.profile-tab{all:unset;cursor:pointer;display:inline-flex;align-items:center;gap:7px;padding:12px 16px;font:500 13px var(--font);color:var(--text-dim);border-bottom:2px solid transparent;transition:var(--transition)}.profile-tab:hover{color:var(--text)}.profile-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.profile-section{padding:24px 28px;display:flex;flex-direction:column;gap:20px}.profile-pref-list{display:flex;flex-direction:column;gap:0}.profile-pref-item{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border-soft)}.profile-pref-item:last-child{border-bottom:none}.profile-pref-icon{width:36px;height:36px;border-radius:var(--r-10);flex-shrink:0;background:var(--border-soft);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.profile-pref-body{flex:1;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0}.profile-pref-label{font-size:14px;font-weight:500;color:var(--text)}.profile-pref-body select{background:var(--surface);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:var(--r-10);font-size:13px;min-width:160px;cursor:pointer;transition:var(--transition)}.profile-pref-body select:hover{border-color:var(--accent)}.profile-hint{font-size:12px;color:var(--text-dim);line-height:1.5;padding:12px 14px;background:var(--border-soft);border-radius:var(--r-10)}.profile-actions{display:flex;justify-content:flex-start;gap:10px;padding-top:4px}.profile-tile-form{display:flex;flex-direction:column;gap:14px;padding:18px;background:var(--border-soft);border-radius:var(--r-14)}.profile-tile-form-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text)}.profile-tile-form-fields{display:flex;flex-direction:column;gap:12px}.profile-form-label{display:flex;flex-direction:column;gap:5px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim)}.profile-form-label input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-10);font-size:14px;background:var(--surface);color:var(--text);transition:var(--transition)}.profile-form-label input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 0 3px var(--accent-soft)}.profile-tile-preview{border:1px solid var(--border);border-radius:var(--r-10);overflow:hidden}.profile-tile-preview-footer{font-size:11px;padding:6px 10px;background:var(--surface);border-top:1px solid var(--border);color:var(--text-dim);text-align:center}.profile-tile-list{display:flex;flex-direction:column;gap:12px}.profile-tile-list-header{font-size:14px;font-weight:600;color:var(--text)}.inline-error{color:var(--danger);font-size:12px}.tile-presets{display:flex;flex-wrap:wrap;gap:8px}.tile-preset{all:unset;cursor:pointer;padding:5px 12px;border:1px solid var(--border);background:var(--surface);border-radius:999px;font-size:12px;color:var(--text);transition:var(--transition)}.tile-preset:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-soft)}.tile-card{border:1px solid var(--border);background:var(--surface);border-radius:var(--r-10);padding:14px;display:flex;flex-direction:column;gap:8px}.tile-card code{font-size:12px;color:var(--text-dim);word-break:break-all}.leaflet-container .leaflet-tile{border:none!important;outline:none!important;box-shadow:none!important}.leaflet-container .leaflet-tile-pane{filter:none!important}[data-theme=dark] .profile-avatar-lg{box-shadow:0 4px 12px -2px #4ade8033}[data-theme=dark] .profile-pref-icon{background:#1a2332}[data-theme=dark] .profile-tile-form,[data-theme=dark] .profile-hint{background:#111827}.sidebar-backdrop{display:none}@media (max-width: 1024px){.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:60}}.leaflet-container{background:var(--surface);font-family:var(--font)}.leaflet-control-layers{background:#fffc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow-1)}.leaflet-bar a{background:var(--surface);color:var(--text-dim);border:1px solid var(--border)}.leaflet-bar a:hover{background:var(--tbl-head-bg);color:var(--text)}.muted-row{opacity:.7}.active-row{outline:2px solid var(--accent);outline-offset:-2px}.inline-badge{background:#f1f5f9;border:1px solid var(--border);color:var(--text-dim);padding:4px 8px;border-radius:999px;font-size:11px}.hl{background:#fff59a;color:inherit;padding:0 1px;border-radius:3px}[data-theme=dark] .hl{background:#3b4500}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;background:linear-gradient(160deg,var(--bg) 0%,var(--surface) 50%,var(--accent-soft) 100%)}.login-card{width:100%;max-width:400px;padding:36px 36px 32px;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-2);text-align:center}.login-logo{margin-bottom:12px}.login-logo img{max-width:100%;height:auto;max-height:200px}.login-title{margin:0 0 4px;font-size:24px;font-weight:700;color:var(--text);letter-spacing:.3px}.login-subtitle{margin:0 0 20px;font-size:13px;color:var(--text-dim);font-weight:400}.login-modes{display:flex;gap:6px;margin-bottom:20px;background:var(--bg);border-radius:12px;padding:4px}.login-mode-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:5px;padding:9px 6px;border:none;border-radius:10px;cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font);background:transparent;color:var(--text-dim);transition:all .2s ease}.login-mode-btn:hover{color:var(--text);background:var(--border-soft)}.login-mode-btn.active{background:var(--accent);color:#fff;box-shadow:0 2px 8px -2px #2f8f4359}.login-form{display:flex;flex-direction:column;gap:0}.login-fields{display:flex;flex-direction:column;gap:14px}.login-label{display:flex;flex-direction:column;gap:5px;text-align:left}.login-label-text{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--text-dim)}.login-label input{width:100%;background:var(--bg);border:1px solid var(--border);padding:11px 14px;font-size:14px;border-radius:10px;color:var(--text);font-family:var(--font);transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.login-label input::placeholder{color:var(--text-faint)}.login-label input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}.login-pwd-wrap{position:relative;display:flex;align-items:center}.login-pwd-wrap input{padding-right:42px}.login-pwd-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:34px;height:34px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;cursor:pointer;font-size:16px;border-radius:8px;transition:background .15s}.login-pwd-toggle:hover{background:var(--border-soft)}.login-wialon-type{display:flex;gap:4px;background:var(--bg);border-radius:8px;padding:3px}.login-wialon-type button{flex:1;padding:7px 8px;border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;font-family:var(--font);background:transparent;color:var(--text-dim);transition:all .15s}.login-wialon-type button.active{background:var(--surface);color:var(--text);box-shadow:0 1px 4px #00000014}.login-hint{font-size:11px;color:var(--text-faint);line-height:1.5;margin:2px 0 0;text-align:left}.login-remember{display:flex;align-items:center;gap:8px;margin:16px 0 0;font-size:13px;color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.login-submit{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-top:16px;padding:13px 20px;background:var(--accent);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background .2s,box-shadow .2s,transform .1s;box-shadow:0 2px 8px -2px #2f8f434d}.login-submit:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 14px -3px #2f8f4366}.login-submit:active:not(:disabled){transform:scale(.98)}.login-submit:disabled{opacity:.65;cursor:not-allowed}.login-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:login-spin .6s linear infinite}@keyframes login-spin{to{transform:rotate(360deg)}}.login-error{display:flex;align-items:center;gap:8px;margin-top:14px;padding:10px 14px;border-radius:10px;background:var(--danger-soft);border:1px solid var(--danger);color:var(--danger);font-size:13px;text-align:left;animation:login-shake .35s ease}.login-error-icon{flex-shrink:0;width:18px;height:18px;border-radius:50%;background:var(--danger);color:#fff;font-size:12px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}@keyframes login-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}.login-meta{font-size:11px;color:var(--text-faint);margin-top:20px;text-align:center;letter-spacing:.3px}.announce-list{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.announce-card{display:flex;align-items:stretch;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-10);overflow:hidden;box-shadow:var(--shadow-1);animation:announce-in .3s ease}@keyframes announce-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.announce-accent{width:4px;flex-shrink:0;background:var(--accent)}.announce-body{flex:1;padding:12px 16px;min-width:0}.announce-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:4px}.announce-text{font-size:13px;color:var(--text-dim);line-height:1.5}.announce-dismiss{flex-shrink:0;align-self:flex-start;margin:8px 8px 0 0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;border-radius:var(--r-6);color:var(--text-faint);cursor:pointer;transition:background .15s,color .15s}.announce-dismiss:hover{background:var(--border-soft);color:var(--text)}@media (max-width: 1024px){.app-shell{flex-direction:column}.sidebar{position:fixed;inset:0 auto 0 0;transform:translate(-100%);transition:transform .25s ease;z-index:70;height:100vh;width:min(280px,80vw)}.sidebar.open{transform:translate(0)}.sidebar.collapsed{width:min(280px,80vw)}.sidebar.collapsed .side-nav a{justify-content:flex-start;padding:8px 10px}.sidebar.collapsed .side-nav a .label,.sidebar.collapsed .brand-title{display:inline}.sidebar.collapsed .profile-mini{justify-content:flex-start}.sidebar.collapsed .profile-mini .username,.sidebar.collapsed .profile-mini .chevron{display:inline}.sidebar.collapsed .collapse-btn{display:none}.sidebar.collapsed .nav-group-title{display:block}.sidebar.collapsed .side-nav a:after{display:none}.sidebar.collapsed .profile-mini:after{display:none}.mobile-topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:65}.mobile-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14px}.hamburger-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;justify-content:center;gap:4px;padding:0 9px;cursor:pointer}.hamburger-btn span{display:block;width:100%;height:2px;background:var(--text);border-radius:2px}.content{padding:16px 14px 80px}}[data-theme=dark] .sidebar{background:#0a0f1a;border-color:#1a2235}[data-theme=dark] .sidebar-header,[data-theme=dark] .sidebar-footer{border-color:#1a2235}[data-theme=dark] .nav-group-title{color:#5a6578}[data-theme=dark] .nav-divider{background:#1a2235}[data-theme=dark] .side-nav a{color:#8b99ad}[data-theme=dark] .side-nav a:hover{background:#111827;color:#e5e7eb}[data-theme=dark] .side-nav a.active{box-shadow:0 2px 6px -2px #00000080}[data-theme=dark] .profile-mini{background:#111827}[data-theme=dark] .profile-mini .username{color:#e5e7eb}[data-theme=dark] .collapse-btn{color:#6b7280}[data-theme=dark] .collapse-btn:hover{background:#1a2235;color:#e5e7eb}[data-theme=dark] .sidebar.collapsed .side-nav a:after,[data-theme=dark] .sidebar.collapsed .profile-mini:after{background:#111827;border-color:#1a2235;color:#e5e7eb}[data-theme=dark] .panel{color:var(--text)}[data-theme=dark] .panel input,[data-theme=dark] .panel select,[data-theme=dark] .panel textarea{color:var(--text);background:#0f172a;border-color:#1f2a44}[data-theme=dark] .panel h3,[data-theme=dark] .panel h2{color:#a7b4c7}[data-theme=dark] .doc-body{color:var(--text)}.logo svg{display:block;height:30px;width:auto}[data-theme=dark] .btn{color:#fff}[data-theme=dark] .btn.secondary{--bg:#1a273f;--bg-hover:#223153;color:#e5e7eb;border-color:#2a3a5f}[data-theme=dark] a.btn.secondary{color:#e5e7eb}[data-theme=dark] .btn .spinner{border-color:#fff9;border-top-color:#fff}[data-theme=dark] .tab-btn{color:#a7b4c7}[data-theme=dark] .tab-btn:hover{color:#e5e7eb}[data-theme=dark] .panel h2,[data-theme=dark] .panel h3{color:#a7b4c7}.inline-filters{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.inline-filters label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-dim)}.inline-filters input[type=date],.inline-filters input[type=number],.inline-filters select{background:#ffffff05;border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:10px;font:500 14px var(--font)}.panel select{background:#ffffff05;border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:10px}form.modern-form button.btn{align-self:end;padding:12px 16px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:999;padding:20px;animation:modal-fade-in .2s ease}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;box-shadow:var(--shadow-3);position:relative;max-height:92vh;overflow-y:auto;animation:modal-slide-up .25s cubic-bezier(.4,0,.2,1)}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-content.size-md{max-width:960px}.modal-content.size-lg{max-width:1200px}.modal-body{padding:28px 30px 32px}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}.modal-header-info h3{font-size:20px;font-weight:700;margin:0 0 4px;color:var(--text);letter-spacing:normal;text-transform:none}.modal-header-info p{font-size:13px;color:var(--text-dim);margin:0}.modal-header-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.modal-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border-radius:10px;border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);z-index:1}.modal-close:hover{background:var(--border-soft);color:var(--text)}.modal-section{border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:16px;background:var(--surface)}.modal-section h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text)}.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding-top:16px;border-top:1px solid var(--border-soft);margin-top:20px}[data-theme=dark] .modal-content{border-color:#1f2a44}[data-theme=dark] .modal-close{background:#0f172a;border-color:#1f2a44;color:#97a3b6}[data-theme=dark] .modal-close:hover{background:#1a273f;color:#e5e7eb}[data-theme=dark] .modal-header-info h3{color:#e5e7eb}.transfer-arrows{display:flex;flex-direction:column;align-items:center;gap:8px;padding-top:52px}.transfer-arrows .btn{width:40px;height:34px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px}.resizer-handle{width:10px;cursor:col-resize;background:var(--border);position:relative;flex-shrink:0;z-index:10;margin:0 3px;border-radius:4px;align-self:stretch;transition:background .15s,width .15s}.resizer-handle:hover{background:var(--accent);width:12px}.resizer-handle:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:3px;height:32px;border-radius:2px;background:#ffffff40}.sidebar-actions-row{display:flex;gap:8px}.icon-only{padding:8px;width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center}.theme-switch{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.theme-switch input{position:absolute;opacity:0;pointer-events:none}.theme-switch .track{width:56px;height:28px;border-radius:999px;background:var(--border-soft);border:1px solid var(--border);position:relative;transition:var(--transition)}.theme-switch .thumb{position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:999px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-1);display:flex;align-items:center;justify-content:center;transition:var(--transition);overflow:hidden}.theme-switch .ico{position:absolute;display:inline-flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--text-dim);transition:var(--transition)}.theme-switch .ico.sun{opacity:1}.theme-switch .ico.moon{opacity:0}.theme-switch input:checked+.track .thumb{transform:translate(28px)}.theme-switch input:checked+.track .thumb .ico.sun{opacity:0}.theme-switch input:checked+.track .thumb .ico.moon{opacity:1}[data-theme=dark] .theme-switch .track{background:#13203b;border-color:#223153}[data-theme=dark] .theme-switch .thumb{background:#0d162c;border-color:#223153}:is(section,[id]){scroll-margin-top:80px}.docs-layout{display:grid;grid-template-columns:260px 1fr;gap:24px}.docs-aside{position:sticky;top:80px;height:fit-content;max-height:calc(100vh - 100px);overflow-y:auto;padding:20px 16px;border-radius:var(--r-14)}.docs-aside-title{font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--accent);margin-bottom:12px;padding-left:8px}.docs-nav-root,.docs-nav-children{list-style:none;margin:0;padding:0}.docs-nav-root>li{margin-bottom:2px}.docs-nav-children{padding-left:14px;border-left:2px solid var(--border-soft);margin:2px 0 6px 10px}.docs-nav-children>li{margin-bottom:1px}.docs-nav-link{display:block;padding:6px 10px;border-radius:var(--r-6);font-size:13px;color:var(--text-dim);text-decoration:none;cursor:pointer;transition:var(--transition);line-height:1.4}.docs-nav-link:hover{background:var(--border-soft);color:var(--text)}.docs-nav-root>li.active>.docs-nav-link,.docs-nav-children>li.active>.docs-nav-link{background:var(--accent-soft);color:var(--accent);font-weight:600}.docs-nav-root>li>.docs-nav-link{font-weight:600;font-size:13.5px;color:var(--text)}.toc{display:flex;flex-direction:column;gap:6px}.toc-link{color:var(--text-dim);text-decoration:none;padding:6px 8px;border-radius:8px}.toc-link:hover{background:var(--border-soft);color:var(--text)}.docs-main{padding:0;overflow:hidden;border-radius:var(--r-14)}.docs-hero{padding:32px 32px 20px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,rgba(47,143,67,.08) 0%,rgba(80,200,120,.03) 50%,transparent 100%)}.docs-hero h1{margin:0 0 6px;font-size:26px;font-weight:700;letter-spacing:-.5px}.docs-hero p{margin:0;color:var(--text-dim);font-size:15px}.docs-content{display:flex;flex-direction:column;gap:0;padding:0 32px 32px}.doc-section{padding:28px 0 24px;border-bottom:1px solid var(--border-soft)}.doc-section:last-of-type{border-bottom:none}.doc-section h2{display:flex;align-items:center;gap:10px;margin:0 0 16px;font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.3px;padding-bottom:10px;border-bottom:2px solid var(--accent);width:fit-content}.doc-section h3{margin:20px 0 10px;font-size:16px;font-weight:600;color:var(--text);padding-left:12px;border-left:3px solid var(--accent-soft)}.doc-section h3:first-child{margin-top:0}.doc-section h4{margin:16px 0 8px;font-size:14px;font-weight:600;color:var(--text)}.doc-section p{margin:0 0 10px;font-size:14px;line-height:1.7;color:var(--text)}.doc-section ul,.doc-section ol{margin:0 0 12px;padding-left:20px;font-size:14px;line-height:1.7}.doc-section li{margin-bottom:4px}.doc-section li strong{color:var(--text)}.lead{font-size:15px;line-height:1.7;color:var(--text)}.docs-feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:16px 0}.docs-feature-card{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border-radius:var(--r-10);border:1px solid var(--border);background:var(--surface);transition:var(--transition)}.docs-feature-card:hover{border-color:var(--accent-soft);box-shadow:0 2px 8px #2f8f4314}.docs-feature-icon{font-size:22px;flex-shrink:0;line-height:1}.docs-feature-card strong{display:block;font-size:13px;margin-bottom:2px}.docs-feature-card span{font-size:12px;color:var(--text-dim);line-height:1.4}.callout{border:1px solid var(--border);background:var(--surface);padding:14px 16px;border-radius:var(--r-10);font-size:13px;color:var(--text);margin:10px 0;position:relative;overflow:hidden}.callout:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px;background:var(--border)}.callout .callout-title{font-weight:700;margin-bottom:6px;font-size:13.5px}.callout p{margin:0 0 6px}.callout p:last-child{margin-bottom:0}.callout ul{margin:4px 0 0;padding-left:18px}.callout.note{background:#f3faf6;border-color:#c8e6d4}.callout.note:before{background:var(--accent)}.callout.warn{background:#fffbf0;border-color:#f5dfa8}.callout.warn:before{background:#e6a817}[data-theme=dark] .callout{background:var(--border-soft)}[data-theme=dark] .callout.note{background:#0e2118;border-color:#153624}[data-theme=dark] .callout.warn{background:#2a1e07;border-color:#3a2a0c}.kbd{display:inline-block;min-width:18px;padding:0 6px;height:20px;line-height:20px;border-radius:6px;background:#fff;border:1px solid var(--border);color:var(--text);font:700 12px var(--font);text-align:center;box-shadow:inset 0 -2px #0000000f}[data-theme=dark] .kbd{background:#0b1223;border-color:#1f2a44;color:#e5e7eb}.step-list{margin:10px 0;padding-left:0;counter-reset:step-counter;list-style:none}.step-list li{counter-increment:step-counter;padding:8px 14px 8px 42px;margin-bottom:6px;position:relative;font-size:14px;line-height:1.6;border-radius:var(--r-6);background:var(--surface);border:1px solid var(--border-soft)}.step-list li:before{content:counter(step-counter);position:absolute;left:10px;top:8px;width:22px;height:22px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.mini-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--r-10);overflow:hidden;border:1px solid var(--border);margin:10px 0;font-size:13px}.mini-table thead th{background:var(--tbl-head-bg);padding:8px 12px;font-weight:600;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim);border-bottom:1px solid var(--border)}.mini-table tbody td{padding:8px 12px;border-bottom:1px solid var(--border-soft)}.mini-table tbody tr:last-child td{border-bottom:none}.mini-table tbody tr:hover{background:var(--border-soft)}.grid-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}.chips{display:flex;gap:6px;flex-wrap:wrap}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:var(--accent-soft);color:var(--accent);border:1px solid var(--accent-soft);border-radius:999px;font-size:12px}.docs-faq-list{display:flex;flex-direction:column;gap:8px;margin:12px 0}.docs-faq-item{padding:14px 16px;border-radius:var(--r-10);border:1px solid var(--border);background:var(--surface);transition:var(--transition)}.docs-faq-item:hover{border-color:var(--accent-soft)}.docs-faq-item h4{margin:0 0 6px;font-size:14px;font-weight:600;color:var(--text)}.docs-faq-item p{margin:0;font-size:13px;line-height:1.6;color:var(--text-dim)}.doc-section h4+p{padding-left:0}.back-to-top{text-align:center;font-size:13px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border-soft)}.back-to-top a{color:var(--text-dim);text-decoration:none;padding:6px 16px;border-radius:var(--r-6);border:1px solid var(--border);transition:var(--transition)}.back-to-top a:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-soft)}@media (max-width: 1024px){.docs-layout{grid-template-columns:1fr}.docs-aside{position:static;max-height:unset}.docs-hero{padding:24px 20px 16px}.docs-content{padding:0 20px 24px}.grid-2{grid-template-columns:1fr}.docs-feature-grid{grid-template-columns:1fr 1fr}}.tour-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:4000;display:flex;align-items:center;justify-content:center;padding:20px}.tour-highlight{position:fixed;pointer-events:none;border-radius:14px;box-shadow:0 0 0 9999px #00000073,0 0 0 3px var(--accent);z-index:4001}.tour-card{width:100%;max-width:520px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-2);padding:16px;z-index:4002}.tour-header{display:flex;align-items:center}.tour-title{font:700 16px var(--font)}.tour-close{margin-left:auto;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:none;color:var(--text-dim);cursor:pointer;font-size:22px;line-height:1;border-radius:8px;padding:4px 6px}.tour-close:hover{background:var(--border-soft);color:var(--text)}.tour-body{margin:10px 0 6px;font-size:14px;line-height:1.6}.tour-footer{display:flex;align-items:center}.tour-steps{font-size:12px;color:var(--text-dim)}.tour-card:after{content:"";position:absolute;width:0;height:0;border:8px solid transparent}.tour-card.tour-card--arrow-left:after{left:-16px;top:20px;border-right-color:var(--surface)}.tour-card.tour-card--arrow-right:after{right:-16px;top:20px;border-left-color:var(--surface)}.tour-card.tour-card--arrow-top:after{top:-16px;left:24px;border-bottom-color:var(--surface)}.tour-card.tour-card--arrow-bottom:after{bottom:-16px;left:24px;border-top-color:var(--surface)}.sampling-point-label{background:none!important;border:none!important;box-shadow:none!important;font-size:11px!important;font-weight:700!important;color:#7c3aed!important;padding:0!important}.wmap-layers{position:absolute;top:10px;left:10px;z-index:500;display:flex;flex-direction:column;gap:6px}.wmap-layer-btn{width:36px;height:36px;border-radius:8px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text-dim, #6b7280);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;box-shadow:0 1px 4px #0000001a}.wmap-layer-btn:hover{border-color:var(--lc);color:var(--lc)}.wmap-layer-btn.active{background:var(--lc);border-color:var(--lc);color:#fff;box-shadow:0 2px 8px #00000026}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;gap:8px}.empty-state-illustration{margin-bottom:8px;opacity:.85}.empty-state-title{font-size:15px;font-weight:600;color:var(--text)}.empty-state-desc{font-size:13px;color:var(--text-dim);max-width:340px;line-height:1.5}.empty-state-action{margin-top:12px}.campaign-card-hover:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}.progress-track{flex:1;height:8px;background:var(--border-soft);border-radius:6px;overflow:hidden}.progress-fill{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--accent),#1f9b51);transition:width .6s cubic-bezier(.4,0,.2,1)}.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.stat-card{display:flex;align-items:flex-start;gap:14px;padding:18px 20px;border-radius:var(--r-14);background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-1);transition:box-shadow var(--transition),transform var(--transition)}.stat-card:hover{box-shadow:var(--shadow-2);transform:translateY(-2px)}.stat-card-icon{width:44px;height:44px;border-radius:var(--r-10);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-body{flex:1;min-width:0}.stat-card-value{font-size:26px;font-weight:700;line-height:1.15;color:var(--text)}.stat-card-label{font-size:12px;font-weight:500;color:var(--text-dim);margin-top:2px;text-transform:uppercase;letter-spacing:.4px}.stat-card-sub{font-size:12px;color:var(--text-faint);margin-top:4px}.skeleton{background:linear-gradient(90deg,var(--border-soft) 25%,var(--border) 50%,var(--border-soft) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-table{display:flex;flex-direction:column;gap:0;border:1px solid var(--border);border-radius:12px;overflow:hidden}.skeleton-thead{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:16px;padding:12px 16px;background:var(--tbl-head-bg);border-bottom:2px solid var(--border)}.skeleton-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:16px;padding:11px 16px;border-bottom:1px solid var(--border-soft)}.skeleton-row:last-child{border-bottom:none}.skeleton-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px}.skeleton-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none;max-width:400px}.toast-item{pointer-events:auto;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;box-shadow:var(--shadow-2);animation:toast-in .25s cubic-bezier(.4,0,.2,1);min-width:260px}.toast-success{border-left:3px solid var(--accent)}.toast-error{border-left:3px solid var(--danger)}.toast-info{border-left:3px solid var(--blue)}.toast-warning{border-left:3px solid var(--amber)}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast-icon{flex-shrink:0}.toast-msg{flex:1;font-size:13px;font-weight:500;color:var(--text);line-height:1.4}.toast-close{flex-shrink:0;width:24px;height:24px;border-radius:6px;border:none;background:transparent;color:var(--text-faint);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .12s}.toast-close:hover{background:var(--border-soft);color:var(--text-dim)}.fld-select-all{display:flex;align-items:center;gap:7px;cursor:pointer;padding:5px 10px;border-radius:8px;transition:background .12s;-webkit-user-select:none;user-select:none}.fld-select-all:hover{background:var(--tbl-hover-bg, rgba(0,0,0,.04))}.fld-select-all input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer;flex-shrink:0}.fld-select-all-label{font-size:12px;font-weight:600;color:var(--text-dim);white-space:nowrap}.fmap-draw-controls{position:absolute;bottom:14px;right:14px;z-index:900;display:flex;align-items:flex-end;gap:8px}.fmap-draw-btn{width:40px;height:40px;border-radius:10px;border:1.5px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text, #333);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;box-shadow:0 2px 8px #0000001f}.fmap-draw-btn:hover{border-color:var(--accent);color:var(--accent)}.fmap-draw-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 12px #0003}.fmap-draw-btn.done{background:#22c55e;border-color:#22c55e;color:#fff}.fmap-draw-panel{background:var(--surface, #fff);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border, #e2e8f0);border-radius:10px;padding:8px 10px;box-shadow:0 2px 10px #0000001f;display:flex;align-items:center;gap:10px}.fmap-draw-status{font-size:12px;font-weight:600;color:var(--text);display:flex;align-items:center;gap:6px;white-space:nowrap}.fmap-draw-dot{width:7px;height:7px;border-radius:50%;background:var(--text-dim, #999);flex-shrink:0}.fmap-draw-dot.active{background:var(--accent);animation:fmap-pulse 1.2s infinite}.fmap-draw-dot.done{background:#22c55e}@keyframes fmap-pulse{0%,to{opacity:1}50%{opacity:.4}}.fmap-draw-actions{display:flex;gap:4px}.fmap-act-btn{width:30px;height:30px;border-radius:7px;border:1px solid var(--border, #e2e8f0);background:var(--surface, #fff);color:var(--text-dim, #888);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .12s}.fmap-act-btn:hover:not(:disabled){border-color:var(--text);color:var(--text)}.fmap-act-btn:disabled{opacity:.35;cursor:default}.fmap-act-btn.confirm:hover:not(:disabled){border-color:#22c55e;color:#22c55e;background:#22c55e14}.fmap-act-btn.danger:hover:not(:disabled){border-color:#ef4444;color:#ef4444;background:#ef444414}.fmap-hint{position:absolute;bottom:14px;left:50%;transform:translate(-50%);z-index:800;background:#000000b8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;font-size:12px;padding:6px 14px;border-radius:8px;white-space:nowrap;pointer-events:none}.field-poly{transition:fill-opacity .15s,stroke-width .15s}.field-poly:hover{fill-opacity:.38!important;stroke-width:3.5!important}.field-tooltip{font-family:Inter,system-ui,sans-serif}.field-tooltip .leaflet-tooltip-content{padding:0}.fmap-session-legend{position:absolute;bottom:14px;left:390px;z-index:800;background:var(--surface, #fff);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid var(--border, #e2e8f0);border-radius:8px;padding:6px 10px;display:flex;gap:12px;box-shadow:0 1px 6px #0000001a}.fmap-legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-dim, #888)}@media (max-width: 640px){.content{padding:12px 10px 70px}.panel{padding:14px 12px 16px;border-radius:12px}.panel-header{gap:6px}.panel-actions{margin-left:0;width:100%;justify-content:flex-start}.topbar{padding:10px 12px;gap:8px;flex-wrap:wrap}.topbar input[type=search]{padding:8px 10px;font-size:13px}.topbar .actions{width:100%}.topbar .actions .btn{flex:1;justify-content:center;font-size:12px;padding:8px 10px}.btn{font-size:13px;padding:9px 12px;border-radius:10px}.btn.small{font-size:11px;padding:6px 8px}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -12px;padding:0 12px}table.modern thead th{padding:8px 10px;font-size:10px;white-space:nowrap}table.modern tbody td{padding:8px 10px;font-size:12px;white-space:nowrap}.toolbar{gap:6px}.toolbar select,.toolbar input[type=date],.toolbar input[type=number]{min-width:0;width:100%;font-size:13px}.inline-filters{gap:8px}.inline-filters label{font-size:12px}.inline-filters input[type=date],.inline-filters input[type=number],.inline-filters select{padding:7px 8px;font-size:13px}.tab-btn{font-size:12px;padding:7px 10px}.form-grid{grid-template-columns:1fr}form.modern-form .inline{flex-direction:column;gap:12px}.profile-pref-body{flex-direction:column;align-items:flex-start;gap:6px}.profile-pref-body select{min-width:0;width:100%}.modal-overlay{padding:0;align-items:flex-end}.modal-content{border-radius:16px 16px 0 0;max-height:92vh}.modal-content.size-md,.modal-content.size-lg{max-width:100%}.modal-body{padding:16px 14px 20px}.modal-header-info h3{font-size:17px}.profile-hero{padding:20px 20px 16px}.profile-avatar-lg{width:44px;height:44px;font-size:16px}.profile-hero-name{font-size:16px}.profile-tabs{padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch}.profile-tab{white-space:nowrap;font-size:12px;padding:10px 12px}.profile-section{padding:18px 20px}.profile-tile-form{padding:14px}.login-wrapper{padding:20px 12px}.login-card{padding:28px 20px 24px;border-radius:16px}.login-title{font-size:20px}.login-modes{gap:4px}.login-mode-btn{padding:8px 4px;font-size:11px}.docs-aside{display:none}.docs-hero{padding:18px 14px 14px}.docs-hero h1{font-size:20px}.docs-hero p{font-size:13px}.docs-content{padding:0 14px 20px}.doc-section h2{font-size:18px}.doc-section h3{font-size:15px}.docs-feature-grid{grid-template-columns:1fr}.docs-feature-card,.announce-body{padding:10px 12px}.announce-title{font-size:13px}.announce-text{font-size:12px}.grid-2{grid-template-columns:1fr;gap:10px}.payroll-summary-grid{grid-template-columns:1fr!important}.transfer-arrows{flex-direction:row;padding-top:0}.overview-works-grid{grid-template-columns:1fr!important;gap:16px!important}.overview-stats-row{gap:12px!important}.settings-grid{grid-template-columns:1fr!important;gap:20px!important}.works-split{flex-direction:column!important}.works-split .resizer-handle{display:none}.works-right-panel{position:static!important;max-height:none!important;width:100%!important}.tour-card{padding:14px}.tour-title{font-size:15px}.tour-body{font-size:13px}.fmap-draw-controls{bottom:10px;right:10px}.fmap-draw-btn{width:36px;height:36px}.fmap-draw-panel{padding:6px 8px}.fmap-draw-status{font-size:11px}.fmap-hint{font-size:11px;bottom:10px}.fmap-session-legend{bottom:10px;left:10px;padding:4px 8px;gap:8px}.fmap-legend-item{font-size:10px}.wmap-layers{top:8px;left:8px;gap:4px}.wmap-layer-btn{width:32px;height:32px;border-radius:6px}}
