:root{--bg: #080808;--bg-soft: #121212;--surface: #171717;--surface-2: #1f1f1f;--border: #2f2f2f;--text: #f5f5f5;--muted: #9a9a9a;--accent: #c5c5c5;--accent-dim: #7e7e7e;--danger: #f87171;--success: #34d399;--radius: 16px;--radius-lg: 22px;--font: "DM Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--page-pad-top: 8px;--page-pad-inline: 16px;--page-pad-bottom: 16px;color-scheme:dark}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;line-height:1;-webkit-user-select:none;user-select:none}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{background:var(--bg)}html,body,#root{min-height:100%;min-height:100dvh;min-height:-webkit-fill-available;margin:0;overflow-x:hidden}body{font-family:var(--font);background-color:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;overflow-x:hidden;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer;touch-action:manipulation}a,button,img{-webkit-touch-callout:none}input,textarea,select,[contenteditable=true]{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}input,textarea,select{width:100%;border:1px solid var(--border);background:#00000080;border-radius:14px;min-height:46px;padding:.7rem .85rem;outline:none}textarea{min-height:88px;resize:vertical}input:focus,textarea:focus,select:focus{border-color:var(--accent-dim);box-shadow:0 0 0 3px #88888838}input[type=checkbox]{width:18px;min-height:18px;padding:0;border-radius:4px}input[type=file]{padding:.6rem;background:#00000080}.preloader-screen{min-height:100dvh;min-height:-webkit-fill-available;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.2rem}.preloader-logo{font-size:1.5rem;font-weight:700;letter-spacing:.22em;color:var(--accent)}.preloader-bar{width:170px;height:4px;background:#ffffff14;border-radius:99px;overflow:hidden}.preloader-bar:after{content:"";display:block;height:100%;width:45%;background:linear-gradient(90deg,var(--accent-dim),var(--accent));border-radius:inherit;animation:slide 1s ease-in-out infinite}@keyframes slide{0%{transform:translate(-100%)}to{transform:translate(230%)}}.login-page{min-height:100dvh;min-height:-webkit-fill-available;display:flex;align-items:center;justify-content:center;padding:calc(1rem + var(--page-pad-top)) calc(1rem + var(--page-pad-inline)) calc(1rem + var(--page-pad-bottom)) calc(1rem + var(--page-pad-inline))}.shell{width:min(100%,560px);margin:0 auto;min-height:100dvh;min-height:-webkit-fill-available;padding:calc(.85rem + var(--page-pad-top)) var(--page-pad-inline) calc(5.3rem + var(--page-pad-bottom)) var(--page-pad-inline)}.shell--login{width:min(100%,460px);min-height:auto;padding:calc(.85rem + var(--page-pad-top)) var(--page-pad-inline) calc(1.2rem + var(--page-pad-bottom)) var(--page-pad-inline)}.shell--edge{width:100%;max-width:100%;padding-left:0;padding-right:0}.shell--app{padding-top:0}.shell--contacts{padding-bottom:calc(6.35rem + var(--page-pad-bottom))}.shell--edge .shell-header{border-radius:0;border-left:none;border-right:none;border-top:none;padding-left:var(--page-pad-inline);padding-right:var(--page-pad-inline)}.native-form{border:1px solid var(--border);background:#161616eb;border-radius:var(--radius-lg);padding:1rem;box-shadow:0 10px 28px #00000059}.login-brand{margin-bottom:.6rem;text-align:center}.login-subtitle{margin:0 0 1rem;text-align:center;color:var(--muted);font-size:.92rem}.shell-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:.7rem;margin-bottom:.8rem;padding:.8rem .75rem;border:1px solid var(--border);border-radius:18px;background:var(--bg);backdrop-filter:none;-webkit-backdrop-filter:none}.shell-header.contacts-header--scrolls{position:static;margin-bottom:.55rem}.contacts-selection-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;min-width:0}.contacts-selection-header__cancel{flex-shrink:0;min-height:40px;padding:0 .65rem;font-size:.9rem}.contacts-selection-header__title{flex:1;min-width:0;text-align:center;font-size:.95rem;font-weight:700;letter-spacing:.03em}.contacts-selection-header__actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0}.contacts-selection-header__actions .material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24}.contacts-selection-header__delete{color:#fecaca;border-color:#b91c1c73}.shell-title-group{min-width:0}.shell-title{font-size:1.06rem;font-weight:700;letter-spacing:.04em}.shell-subtitle{margin-top:.15rem;color:var(--muted);font-size:.79rem}.header-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:.45rem}.header-icon-btn{width:40px;height:40px;border:1px solid var(--border);border-radius:12px;background:#ffffff0a;color:var(--text);display:inline-flex;align-items:center;justify-content:center;padding:0}.header-icon-btn .material-symbols-outlined{font-size:26px}.header-admin-link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .55rem .35rem .4rem;border-radius:12px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);font-size:.88rem;font-weight:600;white-space:nowrap}.header-admin-link .material-symbols-outlined{font-size:22px;opacity:.88}.header-admin-link:active{transform:scale(.98)}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:.6rem .9rem;border:1px solid var(--border);border-radius:14px;background:var(--surface);color:var(--text);font-weight:600;font-size:.9rem;transition:transform .14s ease,border-color .14s ease,background .14s ease}.btn:active{transform:translateY(1px) scale(.99)}.btn-primary{border-color:var(--accent-dim);background:linear-gradient(135deg,#2a2a2a,#171717);color:#efefef}.btn-ghost{background:#ffffff0a}.btn:disabled{opacity:.5;cursor:not-allowed}.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.9rem}.field label{color:var(--muted);font-size:.82rem;font-weight:600}.card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);margin-bottom:.75rem;overflow:hidden;box-shadow:0 8px 22px #0000002e}.card-head{width:100%;border:none;background:transparent;color:inherit;text-align:left;padding:1rem;min-height:60px;display:flex;align-items:center;justify-content:space-between;gap:.7rem}.card-head span.name{font-size:.98rem;font-weight:700}.card-body{border-top:1px solid var(--border);padding:.9rem 1rem 1rem;background:linear-gradient(180deg,#ffffff04,#ffffff01)}.chat-list-item{border-bottom:1px solid var(--border);background:#ffffff03;position:relative;overflow:hidden}.chat-list-item--selected{background:#6366f11f}.chat-list-item--selected .chat-swipe-content{background:transparent}.contact-select-mark{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:2.25rem;color:var(--muted)}.contact-select-mark .material-symbols-outlined{font-size:1.5rem}.chat-list-item--selected .contact-select-mark{color:#a5b4fc}.contacts-infinite-sentinel{height:1px;margin:0;padding:0;visibility:hidden;pointer-events:none}.contacts-load-more-hint{text-align:center;padding:.5rem 1rem 1rem;color:var(--muted);font-size:.85rem}.chat-swipe-actions{position:absolute;right:0;top:0;bottom:auto;height:88px;width:136px;display:grid;grid-template-columns:1fr 1fr;opacity:0;pointer-events:none;transition:opacity .16s ease;border-radius:0 0 0 12px;overflow:hidden}.chat-swipe-content{position:relative;z-index:2;background:inherit;transition:transform .22s ease}.chat-list-item.is-swiped .chat-swipe-content{transform:translate(-136px)}.chat-list-item--keep.is-swiped .chat-swipe-content{transform:translate(-68px)}.chat-list-item.is-swiped .chat-swipe-actions{opacity:1;pointer-events:auto}.chat-swipe-actions.is-disabled{opacity:0!important;pointer-events:none!important}.chat-list-item--keep .chat-swipe-actions{width:68px;height:88px;grid-template-columns:1fr}.chat-swipe-btn{border:none;color:#fff;display:inline-flex;align-items:center;justify-content:center;padding:0}.chat-swipe-btn .material-symbols-outlined{font-size:24px}.chat-swipe-btn--edit{background:#585858}.chat-swipe-btn--delete{background:#b91c1c}.chat-swipe-btn--keep{background:#159947}.chat-list-item .card-head{min-height:88px;padding:.8rem var(--page-pad-inline);justify-content:flex-start}.chat-avatar-wrap{width:64px;height:64px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(145deg,#2a2a2a,#141414)}.chat-avatar{width:100%;height:100%;object-fit:cover;flex-shrink:0;display:block}.chat-avatar-wrap.is-fallback .chat-avatar{transform:scale(1.12)}.chat-avatar-placeholder{width:100%;height:100%;display:block;background:linear-gradient(120deg,#ffffff14 30%,#ffffff29,#ffffff14 70%);background-size:220% 100%;animation:avatarShimmer 1.2s ease-in-out infinite}@keyframes avatarShimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.chat-main{flex:1;display:grid;gap:.16rem;min-width:0;margin-left:.75rem;margin-right:.45rem}.chat-main .name{font-size:.98rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-position,.chat-subline{color:var(--muted);font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-pin-marker{margin-left:.35rem;vertical-align:middle}.chat-pin-marker .material-symbols-outlined{font-size:15px;color:#27c46b}.card-expand{display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s cubic-bezier(.4,0,.2,1)}.card-expand.is-open{grid-template-rows:1fr}.card-expand-inner{overflow:hidden;transition:opacity .35s ease}.card-expand:not(.is-open) .card-expand-inner{opacity:0}.card-expand.is-open .card-expand-inner{opacity:1}.pull-to-refresh{position:fixed;top:0;left:0;right:0;height:52px;display:flex;align-items:center;justify-content:center;z-index:85;pointer-events:none;color:var(--muted);transition:transform .22s ease-out,opacity .2s ease;will-change:transform}.pull-to-refresh--pulling{transition:transform .05s ease-out}.pull-to-refresh__icon{font-size:28px;opacity:.55;line-height:1}.pull-to-refresh--pulling .pull-to-refresh__icon{opacity:.85}.pull-to-refresh__icon--ready{color:#27c46b;opacity:1}.pull-to-refresh--busy .pull-to-refresh__icon{color:var(--accent);opacity:1;animation:pull-to-refresh-spin .75s linear infinite}@keyframes pull-to-refresh-spin{to{transform:rotate(360deg)}}:root[data-theme=light] .pull-to-refresh__icon--ready{color:#16a34a}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:70;display:grid;gap:.2rem;padding:.48rem max(.5rem,var(--page-pad-inline)) calc(.48rem + var(--page-pad-bottom));border-top:1px solid rgba(255,255,255,.1);background:#121212a8;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.bottom-nav--2{grid-template-columns:repeat(2,minmax(0,1fr))}.bottom-nav--with-center{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:flex-end}.bottom-nav-center-add{width:56px;height:56px;margin:0 auto .12rem;border:none;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:transparent;color:var(--muted);cursor:pointer;transition:color .18s ease,filter .18s ease,transform .16s ease}.bottom-nav-center-add:hover,.bottom-nav-center-add:focus-visible{color:#27c46b;filter:drop-shadow(0 0 10px rgba(39,196,107,.38));outline:none}.bottom-nav-center-add--active{color:#27c46b;filter:drop-shadow(0 0 10px rgba(39,196,107,.36))}.bottom-nav-center-add:active{transform:translateY(1px) scale(.985)}.bottom-nav-center-add__icon{transition:opacity .18s ease}.bottom-nav-center-add:hover .bottom-nav-center-add__icon,.bottom-nav-center-add:focus-visible .bottom-nav-center-add__icon,.bottom-nav-center-add--active .bottom-nav-center-add__icon{opacity:1}.bottom-nav-link{min-height:58px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.16rem;border-radius:12px;border:none;background:transparent;color:var(--muted);padding:.2rem .25rem;transition:color .18s ease,transform .16s ease,filter .18s ease}.bottom-nav-link:active{transform:translateY(1px) scale(.985)}.bottom-nav-icon{font-size:30px;opacity:.72}.bottom-nav-label{font-size:.68rem;font-weight:600;letter-spacing:.01em}.bottom-nav-link--active{color:var(--accent);filter:drop-shadow(0 0 10px rgba(185,185,185,.35))}.bottom-nav-link--active .bottom-nav-icon{opacity:1}.contact-inline-list{display:grid;gap:.4rem}.contact-inline-list a{display:block;color:var(--text);background:#ffffff05;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:.62rem .72rem;word-break:break-word}.card-actions{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.85rem;justify-content:flex-end}.card-actions .btn{min-width:130px}.btn-icon{font-size:20px;margin-right:.28rem}.contacts-search-row{display:grid;grid-template-columns:1fr;gap:.45rem;padding:0 .75rem .75rem}.contacts-search-spacer{height:calc(1.1rem + 44px);flex-shrink:0}.contacts-search-row--fixed{position:fixed;left:0;right:0;z-index:25;margin:0;padding:.35rem .75rem .75rem;background:linear-gradient(180deg,#080808f7,#080808eb 55%,#080808e0);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 1px #ffffff0a}.contacts-search-row input{min-height:44px}.filter-icon-btn{width:44px;min-height:44px;border:1px solid var(--border);border-radius:12px;background:#ffffff0a;color:var(--text);display:inline-flex;align-items:center;justify-content:center;padding:0}.filter-icon-btn .material-symbols-outlined{font-size:24px}.filter-options{display:grid;gap:.5rem}.filter-option-row{display:inline-flex;align-items:center;gap:.5rem}.section-title-icon{font-size:1.25rem;vertical-align:text-bottom}.edit-photo-preview-wrap{margin:0 0 .9rem;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#ffffff05}.edit-photo-preview{width:100%;max-height:220px;object-fit:cover;display:block}.toast-stack{position:fixed;left:0;right:0;bottom:calc(5.2rem + var(--page-pad-bottom));z-index:120;display:grid;gap:.5rem;padding:0 .75rem}.toast{position:relative;border:1px solid var(--border);border-radius:14px;background:color-mix(in srgb,var(--surface) 88%,transparent);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:.62rem 2.1rem .62rem .75rem;box-shadow:0 12px 22px #00000047}.toast-title{font-weight:700;font-size:.88rem}.toast-message{margin-top:.12rem;font-size:.8rem;color:var(--muted)}.toast-close{position:absolute;top:.3rem;right:.3rem;border:none;width:28px;height:28px;border-radius:8px;background:transparent;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;padding:0}.toast-close .material-symbols-outlined{font-size:18px}.toast--success{border-color:#34d39961}.toast--error{border-color:#f871716b}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:90;background:color-mix(in srgb,var(--bg) 72%,#000000);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:var(--page-pad-top) max(.8rem,var(--page-pad-inline)) var(--page-pad-bottom) max(.8rem,var(--page-pad-inline))}.modal-backdrop>.contact-create-form,.modal-backdrop>.contact-edit-panel,.modal-backdrop>.contact-detail-panel{width:min(100%,560px);max-height:calc(100dvh - var(--page-pad-top) - var(--page-pad-bottom) - 1rem);overflow:auto;border:1px solid var(--border);border-radius:20px;background:color-mix(in srgb,var(--surface) 78%,transparent);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 24px 50px #00000075;padding:1rem;margin:0}.modal-backdrop>.contact-create-form h3,.modal-backdrop>.contact-edit-panel h3,.modal-backdrop>.contact-detail-panel h3{margin:0 0 .85rem;font-size:1.06rem}.modal-intro{margin:0 0 .85rem}.contact-create-avatar{margin-bottom:1rem}.contact-create-avatar__zone{display:flex;align-items:center;justify-content:center;min-height:120px;border:1px dashed color-mix(in srgb,var(--border) 85%,var(--muted));border-radius:16px;background:color-mix(in srgb,var(--surface) 50%,transparent);cursor:pointer;overflow:hidden;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.contact-create-avatar__zone.is-drag-over{border-color:#ffffff47;border-style:solid;background:color-mix(in srgb,var(--surface) 65%,transparent);box-shadow:inset 0 0 0 1px #ffffff0f}.contact-create-avatar__img{width:100%;max-height:200px;object-fit:cover;display:block}.contact-create-avatar__placeholder{display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1rem;color:var(--muted);font-size:.86rem;text-align:center}.contact-create-avatar__placeholder .material-symbols-outlined{font-size:2rem;opacity:.75}.contact-create-avatar__clear{margin-top:.5rem;width:100%}.contact-create-avatar__clear--outline{border:1px solid rgba(220,38,38,.75);color:#f87171;background:#00000059}.contact-create-avatar__clear--outline:hover{border-color:#ef4444;background:#dc26261f;color:#fecaca}.contact-create-files-hint{margin:0 0 .5rem}.contact-create-files-add{display:flex;align-items:center;justify-content:center;gap:.45rem;padding:.65rem .85rem;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 55%,transparent);cursor:pointer;font-size:.9rem;color:var(--text);margin-bottom:.65rem;transition:border-color .2s ease,background .2s ease}.contact-create-files-add.is-drag-over{border-color:#ffffff47;background:color-mix(in srgb,var(--surface) 70%,transparent)}.contact-create-files-add .material-symbols-outlined{font-size:1.25rem;opacity:.85}.contact-create-file-drafts{list-style:none;margin:0 0 1rem;padding:0;display:flex;flex-direction:column;gap:.45rem}.contact-create-file-draft{display:flex;align-items:center;gap:.55rem;padding:.45rem .5rem;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 60%,transparent)}.contact-create-file-draft__thumb{width:44px;height:44px;object-fit:cover;border-radius:8px;flex-shrink:0}.contact-create-file-draft__icon{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff0f;color:var(--muted)}.contact-create-file-draft__icon .material-symbols-outlined{font-size:1.5rem}.contact-create-file-draft__meta{flex:1;min-width:0;display:flex;flex-direction:column;align-items:stretch;gap:.12rem}.contact-create-file-draft__date{font-size:.72rem;color:var(--muted);padding-left:.05rem}.contact-create-file-draft__name{flex:1;min-width:0;font-size:.86rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-create-file-draft__remove{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:none;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer}.contact-create-file-draft__remove:hover{background:#f8717126;color:#f87171}.contact-doc-name-btn{flex:1;min-width:0;min-height:2.25rem;padding:0 .45rem;justify-content:flex-start;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-context-menu{position:fixed;z-index:95;min-width:200px;max-width:260px;padding:.35rem;border-radius:12px;border:1px solid var(--border);background:color-mix(in srgb,var(--surface) 92%,#000);box-shadow:0 16px 40px #00000073;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.contact-context-menu__item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.55rem .65rem;border:none;border-radius:8px;background:transparent;color:var(--text);font-size:.92rem;text-align:left;cursor:pointer}.contact-context-menu__item .material-symbols-outlined{font-size:1.25rem;opacity:.88}.contact-context-menu__item:hover{background:#ffffff14}.contact-context-menu__item--danger:hover{background:#b91c1ceb;color:#fff}.contact-context-menu__item--danger:hover .material-symbols-outlined{color:#fff;opacity:1}.modal-detail-photo{margin:.75rem 0 0}.modal-detail-photo img{width:100%;border-radius:12px;display:block}.modal-doc-block{margin-top:.75rem}.modal-doc-row{margin-top:.45rem}.modal-doc-row:first-of-type{margin-top:.25rem}.modal-doc-btn{display:block;text-align:left;width:100%;margin-top:0}.modal-doc-date{display:block;font-size:.72rem;color:var(--muted);margin-top:.15rem;padding-left:.1rem}.contact-detail-add-doc{display:inline-flex;align-items:center;gap:.4rem;margin-bottom:.5rem;padding:.45rem .65rem;border-radius:12px;border:1px dashed color-mix(in srgb,var(--border) 85%,transparent);cursor:pointer;font-size:.86rem;color:var(--muted)}.contact-detail-add-doc .material-symbols-outlined{font-size:1.2rem;opacity:.9}.modal-action-full,.modal-close-btn{margin-top:1rem;width:100%}.modal-actions-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1rem}.modal-actions-row .btn{flex:1;min-width:calc(50% - .25rem)}.tag{display:inline-block;margin-right:.35rem;border-radius:999px;background:#ffffff14;color:var(--muted);font-size:.73rem;padding:.2rem .55rem}.section-caption{color:var(--muted);font-size:.84rem;margin-bottom:.45rem}.inline-hint{color:var(--muted);font-size:.8rem;margin:.1rem 0 0}.doc-actions-list{margin-bottom:.8rem}.doc-actions-row{display:flex;gap:.45rem;margin-top:.45rem}.doc-actions-row .btn{flex:1}.error{border:1px solid rgba(248,113,113,.4);background:#f871711f;color:#ffd6d6;border-radius:12px;padding:.6rem .75rem;font-size:.88rem;margin:0 0 .7rem}.success-text{border:1px solid rgba(52,211,153,.34);background:#34d3991f;color:#cef9e8;border-radius:12px;padding:.6rem .75rem;font-size:.88rem;margin:0 0 .7rem}.page-hint{color:var(--muted);font-size:.9rem}.empty-state{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);padding:1.2rem 1rem;text-align:center;box-shadow:0 8px 22px #0000002e}.empty-state h3{margin:0 0 .45rem}.empty-state p{margin:0 0 1rem;color:var(--muted);font-size:.9rem}.shell--admin{padding-bottom:calc(5.5rem + var(--page-pad-bottom))}.admin-page{padding:0 var(--page-pad-inline) .5rem;display:flex;flex-direction:column;gap:1rem;max-width:560px;margin:0 auto}.admin-panel{border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--surface) 88%,transparent);box-shadow:0 12px 32px #00000038;padding:1rem 1rem 1.05rem}.admin-panel--flush-bottom{margin-bottom:.25rem}.admin-panel__head{display:flex;align-items:flex-start;gap:.65rem;margin-bottom:.9rem;padding-bottom:.75rem;border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent)}.admin-panel__icon{font-size:1.75rem;color:var(--muted);opacity:.9;flex-shrink:0;margin-top:.08rem}.admin-panel__title{margin:0;font-size:1.02rem;font-weight:700;letter-spacing:.02em}.admin-panel__sub{margin:.2rem 0 0;font-size:.8rem;color:var(--muted);line-height:1.35}.admin-import-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:112px;padding:1rem;border-radius:14px;border:1px dashed color-mix(in srgb,var(--border) 80%,var(--muted));background:color-mix(in srgb,var(--surface-2) 55%,transparent);cursor:pointer;transition:border-color .2s ease,background .2s ease,opacity .2s ease}.admin-import-zone.is-drag-over{border-style:solid;border-color:#27c46b73;background:color-mix(in srgb,rgba(39,196,107,.12) 40%,var(--surface-2))}.admin-import-zone.is-busy{opacity:.65;pointer-events:none}.admin-import-zone__glyph{font-size:2.25rem;color:var(--muted);opacity:.85}.admin-import-zone__text{font-size:.88rem;color:var(--muted);text-align:center;max-width:16rem;line-height:1.35}.admin-import-progress{width:100%;max-width:18rem;height:5px;border-radius:999px;background:#ffffff14;overflow:hidden;margin-top:.35rem}.admin-import-progress__bar{height:100%;border-radius:999px;background:linear-gradient(90deg,#6366f1,#a78bfa);transition:width .22s ease}.admin-hint-box{margin-top:.75rem;padding:.65rem .75rem;border-radius:12px;font-size:.78rem;line-height:1.45;color:var(--muted);background:#00000047;border:1px solid color-mix(in srgb,var(--border) 60%,transparent)}.admin-hint-box code{font-size:.76rem;padding:.12rem .35rem;border-radius:6px;background:#ffffff0f;color:color-mix(in srgb,var(--text) 85%,var(--muted))}.admin-archive-row{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}.admin-panel>.admin-archive-row{margin-top:0}.admin-archive-actions{display:flex;flex-wrap:wrap;gap:.5rem .65rem;align-items:center}.admin-backup-nas-btn{display:inline-flex;align-items:center;gap:.35rem}.admin-backup-nas-btn__icon{font-size:1.25rem;line-height:1}.admin-archive-btn{display:inline-flex;align-items:center;gap:.45rem;align-self:flex-start}.admin-archive-btn__icon{width:1.25rem;height:1.25rem;flex-shrink:0}.admin-archive-hint{margin:0;font-size:.78rem;line-height:1.45;color:var(--muted)}.admin-archive-hint code{font-size:.76rem;padding:.12rem .35rem;border-radius:6px;background:#ffffff0f;color:color-mix(in srgb,var(--text) 85%,var(--muted))}.admin-new-user-form .field:last-of-type{margin-bottom:.65rem}.admin-form-grid{display:grid;gap:0}@media (min-width: 520px){.admin-form-grid{grid-template-columns:1fr 1fr;gap:0 .75rem}}.admin-submit-btn{width:100%;margin-top:.15rem}.admin-empty-hint{margin:0;font-size:.88rem;color:var(--muted);text-align:center;padding:1.2rem .5rem}.admin-users-list{display:grid;gap:.65rem}.admin-user-card{border:1px solid var(--border);border-radius:16px;background:color-mix(in srgb,var(--surface-2) 92%,transparent);padding:.85rem .9rem;box-shadow:0 4px 14px #0000001f}.admin-user-head{display:flex;align-items:flex-start;justify-content:space-between;gap:.65rem}.admin-user-text{min-width:0}.admin-user-login{font-weight:700;font-size:.95rem}.admin-user-id{color:var(--muted);font-weight:500;font-size:.82rem}.admin-user-meta{margin-top:.2rem;color:var(--muted);font-size:.8rem}.admin-user-toolbar{margin-top:.85rem;padding-top:.75rem;border-top:1px solid color-mix(in srgb,var(--border) 65%,transparent);display:flex;flex-wrap:wrap;align-items:flex-end;gap:.55rem .65rem}.admin-user-field{display:flex;flex-direction:column;gap:.25rem;flex:1 1 140px;min-width:0}.admin-inline-label{font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}.admin-compact-select{min-height:42px}.admin-toggle-inline{display:inline-flex;align-items:center;gap:.45rem;font-size:.88rem;color:var(--text);padding:.35rem 0;flex-shrink:0}.admin-archive-policy{display:flex;align-items:flex-start;gap:.45rem;margin-top:.75rem;max-width:42rem;line-height:1.35}.admin-archive-policy input{margin-top:.2rem;flex-shrink:0}.admin-key-btn{flex:1 1 auto;min-width:min(100%,8rem)}@media (min-width: 480px){.admin-key-btn{flex:0 1 auto;min-width:7.5rem}}.role-chip{display:inline-flex;align-items:center;border-radius:999px;padding:.22rem .6rem;font-size:.72rem;font-weight:600;border:1px solid transparent;flex-shrink:0}.role-chip-1{background:#94a3b81f;border-color:#94a3b852;color:#cbd5e1}.role-chip-2{background:#3b82f624;border-color:#3b82f659;color:#93c5fd}.role-chip-3{background:#eab30824;border-color:#eab30861;color:#fcd34d}.settings-card{border:none;border-bottom:1px solid var(--border);border-radius:0;background:transparent;box-shadow:none;padding:1rem var(--page-pad-inline) .25rem;margin-top:0}.settings-divider{height:1px;background:var(--border);margin:.9rem 0}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-bottom:.9rem}.toggle-row-text{flex:1;min-width:0}.toggle-row-label{font-size:.95rem;font-weight:700}.toggle-row-desc{margin-top:.25rem;color:var(--muted);font-size:.81rem;line-height:1.35}.toggle-track{flex-shrink:0;width:52px;height:30px;border-radius:99px;border:1px solid var(--border);background:#00000080;padding:3px;transition:background .2s ease,border-color .2s ease}.toggle-track--on{border-color:var(--accent-dim);background:linear-gradient(135deg,#3e3e3e,#2b2b2b)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.contact-phone-template{display:grid;gap:.38rem;margin-top:.25rem}.contact-phone-line{display:flex;flex-wrap:wrap;align-items:baseline;gap:.35rem .5rem;font-size:.9rem;line-height:1.35}.contact-phone-label{color:var(--muted);font-weight:600;min-width:6.5rem}.contact-phone-value{color:var(--text);word-break:break-word}.contact-phone-value--plain{color:var(--muted)}.contact-phone-note{color:var(--muted);font-size:.86rem}.contact-phone-empty{margin:.35rem 0 0}.contact-comment-block{margin-top:.85rem;padding:.65rem .75rem;border-radius:12px;border:1px solid var(--border);background:#ffffff08}.contact-comment-text{margin:0;font-size:.9rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}.phone-fields-block{margin-bottom:.5rem}.phone-fields-empty-hint{margin:0 0 .65rem;line-height:1.4}.phone-line-editor{margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.phone-fields-block .phone-line-editor:last-of-type{border-bottom:none;padding-bottom:0;margin-bottom:.35rem}.phone-line-editor__row{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.phone-kind-select{width:5.2rem;flex-shrink:0;min-height:44px;padding:.5rem .35rem;font-size:.82rem}.phone-value-input{flex:1;min-width:0;min-height:44px}.phone-note-input{width:100%;margin-top:.45rem;min-height:42px}.btn-remove-extra{flex-shrink:0;width:40px;height:44px;border:1px solid var(--border);border-radius:12px;background:#ffffff0a;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;padding:0}.btn-remove-extra .material-symbols-outlined{font-size:22px}.btn-add-extra{display:inline-flex;align-items:center;gap:.35rem;margin-top:.35rem;margin-bottom:.5rem;padding:.45rem .6rem;border:1px dashed var(--border);border-radius:12px;background:transparent;color:var(--muted);font-size:.85rem;font-weight:600}.btn-add-extra:active{transform:scale(.99)}.material-symbols--add{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;font-size:22px}.toggle-track:disabled{opacity:.45;cursor:not-allowed}.toggle-thumb{display:block;width:22px;height:22px;border-radius:50%;background:var(--text);box-shadow:0 1px 3px #0000004d;transform:translate(0);transition:transform .2s ease}.toggle-track--on .toggle-thumb{transform:translate(22px)}.toggle-track:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.table{width:100%;border-collapse:collapse;font-size:.86rem}.table th,.table td{border:1px solid var(--border);padding:.45rem .5rem;text-align:left}.table th{color:var(--muted);background:#ffffff0a;font-weight:600}@media (min-width: 768px){.shell{padding-bottom:calc(2rem + var(--page-pad-bottom))}.shell--contacts{padding-bottom:calc(6.35rem + var(--page-pad-bottom))}}:root[data-theme=light]{--bg: #f3f5fb;--bg-soft: #edf1fb;--surface: #ffffff;--surface-2: #f8f9fd;--border: #dde3f1;--text: #1d2432;--muted: #647089;--accent: #5e5e5e;--accent-dim: #8b8b8b;--danger: #dc2626;--success: #059669;color-scheme:light}:root[data-theme=light] body{background-color:var(--bg)}:root[data-theme=light] .shell-header{background:#fff;border-color:var(--border);box-shadow:none}:root[data-theme=light] .native-form{background:#fff;box-shadow:0 8px 20px #0f172a14}:root[data-theme=light] .contacts-search-row--fixed{background:linear-gradient(180deg,#f3f5fbfa,#f3f5fbf0 55%,#f3f5fbeb);box-shadow:0 1px #1d243214}:root[data-theme=light] .header-admin-link{background:#ffffffd9;border-color:var(--border)}:root[data-theme=light] .bottom-nav-center-add{color:#5f6b83}:root[data-theme=light] .bottom-nav-center-add:hover,:root[data-theme=light] .bottom-nav-center-add:focus-visible,:root[data-theme=light] .bottom-nav-center-add--active{color:#059669;filter:drop-shadow(0 0 8px rgba(5,150,105,.35))}:root[data-theme=light] .contact-context-menu__item--danger:hover{background:#b91c1c;color:#fff}:root[data-theme=light] .chat-list-item{background:#ffffffbf}:root[data-theme=light] .bottom-nav{border-top-color:#1d24321a;background:#ffffffbd}:root[data-theme=light] .bottom-nav-link{color:#5f6b83}:root[data-theme=light] .bottom-nav-link--active{color:#4b4b4b;filter:drop-shadow(0 0 8px rgba(120,120,120,.22))}:root[data-theme=light] .admin-panel{background:#ffffffeb;box-shadow:0 10px 28px #0f172a14}:root[data-theme=light] .admin-hint-box{background:#f1f5f9f2;border-color:var(--border)}:root[data-theme=light] .admin-hint-box code{background:#e2e8f0e6;color:var(--text)}:root[data-theme=light] .admin-archive-hint code{background:#e2e8f0e6;color:var(--text)}:root[data-theme=light] .admin-user-card{background:#fffffff2;box-shadow:0 4px 16px #0f172a0f}:root[data-theme=light] .admin-import-zone{background:#f8fafcf2}:root[data-theme=light] .role-chip-1{background:#64748b1f;border-color:#64748b47;color:#475569}:root[data-theme=light] .role-chip-2{background:#2563eb1a;border-color:#2563eb47;color:#1d4ed8}:root[data-theme=light] .role-chip-3{background:#b453091a;border-color:#b453094d;color:#b45309}:root[data-theme=light] .settings-card{background:transparent}:root[data-theme=light] .filter-icon-btn{background:#ffffffbf}:root[data-theme=light] input,:root[data-theme=light] textarea,:root[data-theme=light] select{background:#f7f8fc}:root[data-theme=light] .btn-ghost{background:#ffffffb3}:root[data-theme=light] .toggle-track{background:#dfe5f0}:root[data-theme=light] .toggle-track--on{background:linear-gradient(135deg,#9f9f9f,#7c7c7c)}:root[data-theme=light] .toast{background:#fffffff0;box-shadow:0 12px 28px #0f172a1f}:root[data-theme=light] .modal-backdrop{background:#1d24326b}:root[data-theme=light] .modal-backdrop>.contact-create-form,:root[data-theme=light] .modal-backdrop>.contact-edit-panel,:root[data-theme=light] .modal-backdrop>.contact-detail-panel{background:#fffffff5;box-shadow:0 24px 48px #0f172a24}:root[data-theme=light] .empty-state{background:var(--surface);border-color:var(--border)}:root[data-theme=light] .contact-comment-block{background:#1d24320a}:root[data-theme=light] input[type=file]{background:#eef1f8}:root[data-theme=light] .edit-photo-preview-wrap{background:#1d24320a}
