@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Unbounded:wght@600;700&display=swap";.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px 16px;background:radial-gradient(1200px 440px at 50% -120px,rgba(40,183,154,.14),transparent 68%),linear-gradient(180deg,#eff5f4,#e8efee)}.login-container{position:relative;width:min(480px,100%);padding:34px 30px 30px;border-radius:24px;border:1px solid var(--line-strong);background:radial-gradient(420px 180px at 84% -10%,rgba(40,183,154,.17),transparent 65%),linear-gradient(180deg,#fcfffe,#f4f9f8);box-shadow:var(--shadow-lg)}.login-container:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 0 0 1px #ffffffa6}.login-header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;margin-bottom:20px}.login-pill{display:inline-flex;align-items:center;justify-content:center;min-height:28px;padding:4px 12px;border-radius:999px;background:#063a2314;border:1px solid rgba(6,58,35,.2);color:var(--brand-700);font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase}.login-header h1{margin:0;font-family:Unbounded,Manrope,sans-serif;font-size:34px;line-height:1;font-weight:700;color:var(--text-strong)}.login-header p{margin:0;color:var(--muted);font-size:14px;font-weight:600}.login-form{display:flex;flex-direction:column;gap:14px}.login-step{margin:2px 0;font-size:13px;font-weight:800;color:#3d5852;text-align:center}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{margin:0;font-size:12px;font-weight:800;color:#3f5b55;letter-spacing:.04em;text-transform:uppercase}.form-group input{height:46px;padding:0 14px;border:1px solid #a9beb8;border-radius:12px;background:#fbfdfd;color:#122a25;outline:none;font:700 15px/1 Manrope,sans-serif;transition:border-color .16s ease,box-shadow .16s ease}.form-group input::-moz-placeholder{color:#7f9791}.form-group input::placeholder{color:#7f9791}.form-group input:focus{border-color:#26a68c;box-shadow:var(--focus)}.form-group input:disabled{opacity:.7;cursor:not-allowed}.login-error{padding:10px 12px;border:1px solid rgba(218,75,73,.3);border-radius:12px;background:#da4b491a;color:#b23432;font-size:13px;font-weight:700;text-align:center}.login-button{margin-top:2px;min-height:46px;height:46px;border-radius:14px;border:1px solid #0f6b5c;background:linear-gradient(135deg,#0f6b5c,#1a8f79 55%,#28b79a);color:#effff8;font:800 16px/1 Manrope,sans-serif;letter-spacing:.01em;cursor:pointer;box-shadow:0 14px 26px #063a352e;transition:all .16s ease}.login-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 32px #063a3538}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 560px){.login-page{padding:10px}.login-container{padding:24px 16px;border-radius:16px}.login-header h1{font-size:28px}}:root{--brand-900: #063a35;--brand-800: #0a4d44;--brand-700: #106257;--brand-600: #177a6b;--brand-500: #1f9a84;--brand-400: #28b79a;--bg-main: #edf3f1;--bg-soft: #f6fbf9;--surface: #ffffff;--surface-soft: #f7fbfa;--text: #102723;--text-strong: #081815;--muted: #5a7069;--line: #d7e3df;--line-strong: #bfcec9;--line-soft: #e8f0ed;--danger: #da4b49;--danger-strong: #b83232;--ok: #1f9f5f;--warning: #e39d24;--info: #2f6fe0;--radius-xs: 10px;--radius-sm: 12px;--radius: 16px;--radius-lg: 20px;--shadow-sm: 0 2px 10px rgba(6, 58, 53, .08);--shadow-md: 0 14px 34px rgba(6, 58, 53, .11);--shadow-lg: 0 26px 68px rgba(6, 58, 53, .16);--focus: 0 0 0 3px rgba(31, 154, 132, .25)}*{box-sizing:border-box}html,body,#root{min-height:100%}html{background:var(--bg-main)}body{margin:0;color:var(--text);font:14px/1.45 Manrope,Segoe UI,sans-serif;background:radial-gradient(900px 540px at -12% -18%,rgba(31,154,132,.22),transparent 58%),radial-gradient(860px 520px at 112% 5%,rgba(6,58,53,.16),transparent 56%),linear-gradient(180deg,#f4faf7,#edf3f1 45%,#e6efec);background-attachment:fixed}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.3;background-image:linear-gradient(rgba(11,70,60,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(11,70,60,.035) 1px,transparent 1px);background-size:28px 28px}a{color:inherit}::-moz-selection{background:#1f9a8447;color:var(--text-strong)}::selection{background:#1f9a8447;color:var(--text-strong)}.app-shell{position:relative;display:grid;grid-template-columns:272px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;z-index:12;height:100vh;display:flex;flex-direction:column;background:linear-gradient(185deg,#073630fa,#052522fa);border-right:1px solid rgba(255,255,255,.16);box-shadow:22px 0 52px #03181557}.brand{display:flex;align-items:center;gap:12px;padding:18px 16px;border-bottom:1px solid rgba(255,255,255,.12)}.brand-mark{width:42px;height:42px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;font-family:Unbounded,Manrope,sans-serif;font-size:13px;font-weight:700;letter-spacing:.06em;color:#d2fff5;background:linear-gradient(145deg,#28b79ab8,#086c5ccc);box-shadow:inset 0 0 0 1px #ffffff47,0 12px 24px #00000047}.brand-copy{display:flex;flex-direction:column;min-width:0}.brand-copy strong{font-family:Unbounded,Manrope,sans-serif;font-size:15px;font-weight:700;letter-spacing:.02em;color:#f5fffc}.brand-copy span{color:#cdeae1cc;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.side-nav{display:flex;flex-direction:column;gap:4px;padding:12px 10px;overflow:auto}.nav-item{position:relative;display:flex;align-items:center;min-height:40px;padding:10px 12px 10px 16px;border-radius:12px;color:#ddf0eae0;text-decoration:none;border:1px solid transparent;transition:all .18s ease}.nav-item:before{content:"";width:6px;height:6px;border-radius:999px;margin-right:10px;background:#b8ddd373;transition:all .18s ease}.nav-item:hover{color:#f8fffd;border-color:#b1e6d840;background:#b4e6d81a}.nav-item.active{color:#041d19;background:linear-gradient(135deg,#bef1e3,#84dbc4);border-color:#ffffff52;box-shadow:0 8px 18px #00000040}.nav-item.active:before{background:#0f5f52}.side-footer{margin-top:auto;padding:14px;border-top:1px solid rgba(255,255,255,.12);background:linear-gradient(180deg,#fff0,#12463e70)}.side-user{margin-bottom:10px;font-size:12px;color:#d2ebe3e0}.side-logout{width:100%;justify-content:center}.sidebar .btn.ghost{background:#ffffff14;border-color:#ffffff3d;color:#e5faf4;box-shadow:none}.sidebar .btn.ghost:hover{background:#ffffff24;border-color:#ffffff57}.main{min-width:0;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;gap:12px;min-height:74px;padding:14px 20px;background:#f6fbf9e0;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.search{width:100%;max-width:580px;height:44px;border:1px solid var(--line-strong);border-radius:12px;padding:0 14px;background:#fffffff2;color:var(--text);outline:none;font:600 14px/1 Manrope,sans-serif;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}.search::-moz-placeholder{color:#7f948e}.search::placeholder{color:#7f948e}.search:focus{border-color:var(--brand-500);box-shadow:var(--focus);background:#fff}.top-actions{margin-left:auto;display:flex;align-items:center;gap:10px}.top-user{display:flex;flex-direction:column;padding:8px 12px;border-radius:12px;border:1px solid var(--line);background:#fffffff2}.top-user__name{font-size:12px;font-weight:800;color:var(--text-strong)}.top-user__role{font-size:11px;color:var(--muted)}.content{width:100%;min-width:0;padding:18px}.content>*{animation:riseIn .28s ease both}@keyframes riseIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.sidebar-overlay{display:none}.menu-btn{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;border:1px solid var(--line-strong);background:#fff;color:var(--text-strong);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .16s ease}.menu-btn:hover{border-color:var(--brand-500)}.menu-btn:active{transform:translateY(1px)}.menu-icon{width:18px;height:2px;border-radius:99px;background:var(--brand-800);position:relative}.menu-icon:before,.menu-icon:after{content:"";position:absolute;left:0;width:18px;height:2px;border-radius:99px;background:var(--brand-800)}.menu-icon:before{top:-5px}.menu-icon:after{top:5px}.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px}.title,.page-head .title{margin:0;font-family:Unbounded,Manrope,sans-serif;font-size:20px;font-weight:700;letter-spacing:.01em;color:var(--text-strong)}.head-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.head-search{width:min(480px,100%)}.card{width:100%;border-radius:var(--radius);background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-sm)}.card.padded{padding:16px}.table{width:100%;display:flex;flex-direction:column}.thead,.trow{width:100%;display:grid;gap:12px;align-items:center;padding:12px 16px}.thead{position:sticky;top:0;z-index:1;background:linear-gradient(180deg,#f7fbfa,#f1f8f5);border-bottom:1px solid var(--line);color:#4f6660;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.trow{border-top:1px solid var(--line-soft);transition:background .18s ease}.trow:hover{background:#f8fcfb}.empty{padding:26px 18px;text-align:center;color:var(--muted);font-weight:600}.tbl-thumb{width:56px;height:40px;border-radius:10px;border:1px solid var(--line);-o-object-fit:cover;object-fit:cover;background:#eef5f2}.cell{min-width:0}.cell-label{display:none}.cell-value{min-width:0}.row-actions{width:100%;display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:nowrap}.row-actions .btn{flex:1 1 0;min-width:0}.orders-table .row-actions{justify-content:flex-end}.orders-table .row-actions .btn{flex:0 0 auto;min-width:88px}.cities-toolbar{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:12px}.cities-toolbar .form-group{margin:0;min-width:220px;flex:1}.cities-toolbar-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.cities-region-block{margin-bottom:12px}.cities-region-head{width:100%;min-height:52px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 10px 8px 14px;border:1px solid var(--line);border-radius:14px;background:linear-gradient(180deg,#f8fcfb,#f0f7f4);color:var(--text-strong);transition:all .16s ease}.cities-region-head:hover{border-color:#a8c7be;box-shadow:0 8px 18px #063a3514}.cities-region-toggle{flex:1;min-height:38px;display:flex;align-items:center;justify-content:space-between;gap:10px;border:0;background:transparent;color:inherit;cursor:pointer;padding:0;text-align:left}.cities-region-controls{display:inline-flex;align-items:center;gap:8px}.cities-region-head-main{display:inline-flex;align-items:center;gap:10px}.cities-region-name{font-size:15px;font-weight:800}.cities-region-caret{font-size:18px;line-height:1;color:#44635b;transform:rotate(0);transition:transform .16s ease}.cities-region-caret.collapsed{transform:rotate(-90deg)}.cities-region-block .card{margin-top:8px}.cities-region-block .thead{position:static}.cities-switch-wrap{display:inline-flex;align-items:center;gap:8px}.chat-page{display:flex;flex-direction:column;gap:12px}.chat-page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}.chat-page-subtitle{margin:6px 0 0;color:var(--muted);font-size:13px;font-weight:700}.chat-page-stats{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap}.chat-stat{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;border:1px solid var(--line);background:#ffffffbd;color:#31574e;font-size:12px;font-weight:800}.chat-stat strong{margin-left:5px;color:var(--text-strong)}.chat-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:12px;border-style:solid;background:linear-gradient(180deg,#fbfefd,#f4faf7)}.chat-toolbar__search{flex:1 1 340px;min-width:220px}.chat-toolbar__search .head-search{width:100%}.chat-toolbar__actions{display:flex;align-items:center;gap:10px;margin-left:auto}.chat-sync{display:inline-flex;align-items:center;gap:8px;min-height:36px;padding:0 12px;border-radius:12px;border:1px solid #cddfd9;background:#fff;color:#4f6e66;font-size:12px;font-weight:700;white-space:nowrap}.chat-sync:before{content:"";width:8px;height:8px;border-radius:999px;background:#7ca49a}.chat-sync.is-active:before{background:var(--brand-500);animation:chatSyncPulse 1s ease infinite}.chat-error{margin-bottom:0}.chat-admin{overflow:hidden}.chat-admin__top{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#fbfefd,#f4faf7)}.chat-admin__top-title{font-size:13px;font-weight:900;letter-spacing:.04em;text-transform:uppercase;color:#2e564d}.chat-admin__top-note{color:var(--muted);font-size:12px;font-weight:700}.chat-admin__scroll{height:calc(100vh - 250px);min-height:500px;overflow:auto;padding:14px;background:radial-gradient(760px 220px at 2% 0%,rgba(31,154,132,.12),transparent 60%),radial-gradient(760px 220px at 98% 0%,rgba(6,58,53,.06),transparent 58%),linear-gradient(180deg,#f8fcfb,#f2f8f6)}.chat-admin__day{position:sticky;top:6px;z-index:2;width:-moz-fit-content;width:fit-content;margin:10px auto;padding:6px 12px;border-radius:999px;border:1px solid #d2e4df;background:#fffffff2;color:#56716a;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;box-shadow:0 8px 18px #063a3514}.chat-msg{display:grid;grid-template-columns:42px minmax(0,1fr) auto;align-items:flex-start;gap:12px;padding:10px;border:1px solid transparent;border-radius:14px;transition:background .16s ease,border-color .16s ease}.chat-msg:hover{border-color:#d7e4e0;background:#ffffffb8}.chat-msg__avatar{width:42px;height:42px;border-radius:13px;border:1px solid #c2dbd4;background:linear-gradient(160deg,#d7f3eb,#c1e8db);color:var(--brand-800);display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:900}.chat-msg__body{min-width:0}.chat-msg__meta{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px}.chat-msg__identity{display:flex;align-items:center;flex-wrap:wrap;gap:7px;min-width:0}.chat-msg__name{min-width:0;font-size:14px;font-weight:800;color:var(--text-strong)}.chat-msg__id{color:#577068;font-size:11px;font-weight:700;font-family:IBM Plex Mono,Menlo,monospace}.chat-msg__blocked{margin-left:2px}.chat-msg__time{flex:0 0 auto;color:var(--muted);font-size:11px;font-weight:700;font-family:IBM Plex Mono,Menlo,monospace}.chat-bubble{display:flex;flex-direction:column;gap:8px;max-width:880px;border:1px solid #d4e5e0;background:linear-gradient(180deg,#fff,#f8fcfb);border-radius:14px;padding:12px}.chat-bubble__quote{border-left:3px solid #8dbfb2;border-radius:8px;background:#8dbfb21f;padding:8px 10px}.chat-bubble__quote.is-reply{border-left-color:#1f9a84;background:#1f9a841f}.chat-bubble__quote-label{color:#1f4f45;font-size:12px;font-weight:800;line-height:1.25;margin-bottom:2px}.chat-bubble__quote-text{color:#3f6259;font-size:12px;font-weight:700;line-height:1.35;white-space:pre-wrap;overflow-wrap:anywhere}.chat-bubble__text{margin:0;white-space:pre-wrap;overflow-wrap:anywhere;color:#173c34;line-height:1.45}.chat-media{margin-top:10px;padding-top:10px;border-top:1px dashed #cde0da}.chat-media__meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.chat-media__link{color:#0e6f5f;font-size:12px;font-weight:800;text-decoration:none}.chat-media__link:hover{text-decoration:underline}.chat-media__preview-link{display:inline-flex;margin-top:10px}.chat-img{width:min(360px,100%);max-width:100%;height:auto;border-radius:12px;border:1px solid #cfe0db;background:#eef5f2;-o-object-fit:cover;object-fit:cover}.chat-msg__actions{display:flex;align-items:center;justify-content:flex-end;align-content:flex-start;gap:8px;min-width:220px;flex-wrap:wrap}.chat-msg__readonly{display:flex;align-items:center;justify-content:flex-end;gap:8px}.chat-msg__readonly .text-muted{font-size:12px;font-weight:700}.chat-msg.is-blocked{border-color:#da4b4938;background:#da4b490a}.chat-msg.is-blocked .chat-bubble{border-color:#da4b495c;background:#da4b490d}@keyframes chatSyncPulse{0%,to{transform:scale(1)}50%{transform:scale(1.35)}}.users-page-head{margin-bottom:22px}.users-title{font-size:24px}.users-subtitle{margin-top:6px;color:var(--muted);font-size:14px}.users-filters-card{margin-bottom:18px;padding:16px;background:linear-gradient(180deg,#fdfefe,#f6fbf9);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.users-filters-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:10px;margin-bottom:12px}.users-filter-input,.users-filter-select{height:42px;width:100%;padding:0 13px;border:1px solid var(--line-strong);border-radius:12px;background:#fff;color:var(--text);outline:none;transition:border-color .16s ease,box-shadow .16s ease}.users-filter-input::-moz-placeholder{color:#80948f}.users-filter-input::placeholder{color:#80948f}.users-filter-input:focus,.users-filter-select:focus{border-color:var(--brand-500);box-shadow:var(--focus)}.users-filters-stats{display:flex;flex-wrap:wrap;gap:8px 14px;color:var(--muted);font-size:12px}.users-filters-stats strong{color:var(--text-strong)}.form{display:grid;gap:12px}.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.col-2{grid-column:1 / -1}.field{min-width:0}.field label{display:block;margin:0 0 6px;color:#5a7069;font-size:12px;font-weight:800;letter-spacing:.02em}.profile-page{display:flex;flex-direction:column;gap:12px}.profile-subtitle{margin-top:6px;color:var(--muted);font-weight:700}.profile-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:14px}.profile-card-title{margin:0 0 12px;font-size:16px;font-weight:900;color:var(--text-strong)}.profile-2fa-status{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px}.profile-totp-setup{display:flex;flex-direction:column;gap:12px}.profile-totp-qr-wrap{width:232px;height:232px;border-radius:14px;border:1px solid var(--line);background:linear-gradient(180deg,#f6fbf9,#eef6f3);display:flex;align-items:center;justify-content:center;overflow:hidden}.profile-totp-qr{width:220px;height:220px;display:block;-o-object-fit:contain;object-fit:contain}.profile-totp-no-qr{width:100%;padding:0 18px;text-align:center;color:var(--muted);font-weight:700}.profile-secret-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.profile-totp-disable{display:flex;flex-direction:column;gap:10px;max-width:420px}input:not([type=checkbox]):not([type=radio]):not([type=file]),select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:12px;background:#fff;color:var(--text);outline:none;font:600 14px/1.35 Manrope,sans-serif;transition:border-color .16s ease,box-shadow .16s ease,background .16s ease}input:not([type=checkbox]):not([type=radio]):not([type=file]),select{height:42px;padding:0 12px}textarea{min-height:120px;padding:10px 12px;resize:vertical}input:not([type=checkbox]):not([type=radio]):not([type=file])::-moz-placeholder,textarea::-moz-placeholder{color:#80948f}input:not([type=checkbox]):not([type=radio]):not([type=file])::placeholder,textarea::placeholder{color:#80948f}input:not([type=checkbox]):not([type=radio]):not([type=file]):focus,select:focus,textarea:focus{border-color:var(--brand-500);box-shadow:var(--focus)}input[type=checkbox],input[type=radio]{accent-color:var(--brand-600)}.preview{width:100%;min-height:180px;border:1px dashed var(--line-strong);border-radius:14px;background:linear-gradient(180deg,#f6fbf9,#edf5f2);-o-object-fit:cover;object-fit:cover}.pre{overflow:auto;padding:10px;border-radius:10px;background:#0d1f1b;color:#d8f0ea}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:34px;background-image:linear-gradient(45deg,transparent 50%,#4f6a63 50%),linear-gradient(135deg,#4f6a63 50%,transparent 50%);background-position:calc(100% - 17px) calc(50% - 2px),calc(100% - 11px) calc(50% - 2px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;height:40px;padding:0 14px;border:1px solid var(--line-strong);border-radius:12px;background:#fff;color:#13312b;font:800 13px/1 Manrope,sans-serif;letter-spacing:.01em;white-space:nowrap;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:0 1px #ffffffe6,0 8px 16px #063a3514;transition:all .16s ease}.btn:hover{border-color:#9ec7bb;transform:translateY(-1px);box-shadow:0 14px 24px #063a351c}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}.btn.primary{border-color:#0f6b5c;color:#eafff8;background:linear-gradient(135deg,#0f6b5c,#1a8f79 55%,#28b79a);box-shadow:0 12px 24px #063a3533}.btn.primary:hover{filter:saturate(1.04) brightness(1.02)}.btn.ghost{background:#f7fbfa;color:#1b4a40}.btn.danger{border-color:#b93a3a;color:#fff;background:linear-gradient(140deg,#da4b49,#b83232)}.btn.xs{min-height:34px;height:34px;border-radius:10px;padding:0 12px;font-size:12px;min-width:88px}.badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:4px 10px;border-radius:999px;border:1px solid #cde2dc;background:#edf5f2;color:#24574e;font-size:12px;font-weight:800}.badge.ok{border-color:#1f9f5f47;background:#1f9f5f1f;color:#1f874f}.badge.muted{border-color:#d9e8e3;background:#f4f9f7;color:#5c746d}.badge.danger{border-color:#da4b4947;background:#da4b491a;color:#bb3f3d}.badge.warning{border-color:#e39d244d;background:#e39d2424;color:#a26a12}.badge.info{border-color:#2f6fe04d;background:#2f6fe01f;color:#245cbe}.switch{position:relative;width:46px;height:26px;border-radius:999px;border:1px solid #c4d7d1;background:#e9f2ef;cursor:pointer;transition:all .16s ease}.switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 4px 10px #063a352e;transition:left .16s ease}.switch.on{border-color:#0f6b5c;background:linear-gradient(135deg,#0f6b5c,#28b79a)}.switch.on:after{left:calc(100% - 22px)}.switch:disabled{opacity:.55;cursor:not-allowed}.icon-btn{width:34px;height:34px;border-radius:10px;border:1px solid var(--line-strong);background:#fff;color:var(--text);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .16s ease}.icon-btn:hover{border-color:var(--brand-500);color:var(--brand-700)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:60;padding:20px;display:flex;align-items:center;justify-content:center;background:#03181573;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.modal-card{width:100%;border-radius:20px;border:1px solid #cfdfda;background:#fff;box-shadow:var(--shadow-lg);overflow:hidden}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line);background:linear-gradient(180deg,#f8fcfb,#f2f8f5)}.modal-title{font-size:16px;font-weight:900;color:var(--text-strong)}.modal-body{padding:16px}.modal-footer,.modal-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap;margin-top:10px}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.alert{border-radius:12px;border:1px solid #cde2dc;background:#f4faf8;color:#1e4c43;padding:10px 12px;font-weight:700}.alert.error{border-color:#da4b494d;background:#da4b491a;color:#b23432}.alert.ok{border-color:#1f9f5f4d;background:#1f9f5f1f;color:#1a7f46}.toast-viewport{position:fixed;top:16px;right:16px;z-index:100;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{min-width:290px;max-width:430px;pointer-events:auto;border-radius:14px;border:1px solid #cfe0db;background:#fffffff0;box-shadow:var(--shadow-md);padding:12px}.toast-row{display:flex;gap:10px;justify-content:space-between;align-items:flex-start}.toast-title{font-size:13px;font-weight:900;color:var(--text-strong);margin-bottom:2px}.toast-msg{margin:0;color:var(--muted);font-size:13px;line-height:1.3}.toast-close{width:30px;height:30px;border-radius:10px;border:1px solid #d3e1dd;background:#fff;color:#1f4e45;cursor:pointer}.toast.ok{border-color:#1f9f5f4d}.toast.error{border-color:#da4b4957}.toast.warning{border-color:#e39d2459}.text-muted,.muted{color:var(--muted)}.text{color:var(--text)}.mono{font-family:IBM Plex Mono,Menlo,monospace}.kpi{color:var(--brand-700);font-weight:900}.surface{border:1px solid var(--line);border-radius:14px;padding:12px;background:linear-gradient(180deg,#f8fcfb,#f2f8f6)}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:61;background:#03181559}.drawer{position:fixed;top:0;right:0;z-index:62;width:min(760px,100vw);height:100vh;background:#fff;border-left:1px solid var(--line);box-shadow:-22px 0 44px #063a3533;display:flex;flex-direction:column}.drawer-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--line)}.drawer-body{flex:1;overflow:auto;padding:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.drawer-foot{padding:14px 16px;border-top:1px solid var(--line);display:flex;justify-content:flex-end;gap:8px}.boot-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--text-strong)}.boot-dot{width:14px;height:14px;border-radius:999px;background:linear-gradient(135deg,var(--brand-700),var(--brand-400));box-shadow:0 0 0 8px #1f9a841f;animation:bootPulse 1s ease infinite}@keyframes bootPulse{0%,to{transform:scale(1)}50%{transform:scale(1.16)}}@media (max-width: 1120px){.profile-grid{grid-template-columns:1fr}.users-filters-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.users-filter-input{grid-column:1 / -1}.chat-page-head{align-items:flex-start}.chat-toolbar__actions{width:100%;justify-content:space-between;margin-left:0}.chat-sync{flex:1}.chat-msg{grid-template-columns:42px minmax(0,1fr)}.chat-msg__actions{grid-column:2;min-width:0;justify-content:flex-start}.chat-msg__readonly{justify-content:flex-start}}@media (max-width: 900px){.app-shell{grid-template-columns:240px 1fr}.topbar{flex-wrap:wrap;min-height:auto;padding:12px}.search{max-width:none;flex:1}.top-actions{width:100%;justify-content:space-between}.head-actions{width:100%}.head-actions .btn,.head-actions .select,.head-search{flex:1;min-width:160px}.cities-toolbar .form-group{min-width:180px}}@media (max-width: 640px){.app-shell{display:block}.sidebar{position:fixed;top:0;left:0;bottom:0;width:min(88vw,320px);transform:translate(-104%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:11;opacity:0;pointer-events:none;background:#0000004d;transition:opacity .2s ease}.sidebar-overlay.open{opacity:1;pointer-events:auto}.menu-btn{display:inline-flex}.content{padding:12px}.title,.page-head .title{font-size:17px}.table{padding:10px;gap:10px}.thead{display:none}.trow{display:block;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px 12px}.cell{display:flex;gap:10px;justify-content:space-between;align-items:flex-start;border-top:1px solid var(--line-soft);padding:8px 0}.cell:first-child{border-top:0}.cell-label{display:block;flex:0 0 42%;color:var(--muted);font-size:12px;font-weight:700}.cell-value{flex:1;text-align:right;overflow-wrap:anywhere}.row-actions{flex-wrap:wrap;justify-content:flex-end}.row-actions .btn,.row-actions .btn.xs{flex:1 0 calc(50% - 4px);min-width:0}.cities-toolbar{gap:10px;margin-bottom:10px}.cities-toolbar .form-group{min-width:100%}.cities-toolbar-actions{width:100%}.cities-toolbar-actions .btn{flex:1;min-width:0}.cities-region-name{font-size:14px}.cities-region-head{flex-wrap:wrap;align-items:flex-start;padding-right:12px}.cities-region-toggle{width:100%}.cities-region-controls{width:100%;justify-content:flex-end}.profile-secret-row{grid-template-columns:1fr}.profile-totp-qr-wrap{width:100%;max-width:232px}.chat-admin__scroll{min-height:420px;height:calc(100vh - 270px);padding:10px}.chat-page-stats{width:100%;justify-content:flex-start}.chat-toolbar{padding:10px}.chat-toolbar__search{flex:1 1 100%;min-width:0}.chat-toolbar__actions{width:100%;justify-content:flex-start;gap:8px;flex-wrap:wrap}.chat-sync{width:100%;justify-content:center;white-space:normal}.chat-admin__top{flex-direction:column;align-items:flex-start;gap:4px}.chat-msg{grid-template-columns:1fr;gap:8px;padding:10px}.chat-msg__avatar{width:34px;height:34px;border-radius:10px}.chat-msg__meta{flex-direction:column;align-items:flex-start;gap:4px}.chat-msg__actions{grid-column:auto;min-width:0;width:100%;justify-content:flex-start;flex-wrap:wrap}.chat-msg__readonly{width:100%;justify-content:space-between;flex-wrap:wrap}.users-title{font-size:20px}.users-filters-card{padding:12px}.users-filters-grid{grid-template-columns:1fr}.users-filter-input,.users-filter-select{height:40px}.modal-backdrop{padding:0;align-items:stretch}.modal-card{max-width:100%!important;width:100%;height:100%;border-radius:0}.modal-body{padding:12px;overflow:auto}.grid-2,.grid-3,.drawer-body{grid-template-columns:1fr}}@media (min-width: 641px){.menu-btn{display:none}}
