.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--petrol) 0%,var(--petrol-dark) 100%);position:relative;overflow:hidden;padding:24px}.login-decoration{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.login-circle{position:absolute;border-radius:50%;background:#ffffff0a}.login-circle-1{width:400px;height:400px;top:-100px;right:-100px}.login-circle-2{width:300px;height:300px;bottom:-80px;left:-80px}.login-circle-3{width:200px;height:200px;top:40%;left:10%;background:#f0c73f0f}.login-card{background:var(--white);border-radius:20px;padding:48px 40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg);position:relative;z-index:1;animation:slideUp .4s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:36px}.login-logo-img{height:36px;width:auto}.login-subtitle{font-size:14px;color:var(--grey-light);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:2px}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:13px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:.5px}.login-field input{padding:14px 16px;border:2px solid var(--grey-border);border-radius:var(--radius-sm);font-size:16px;color:var(--grey);outline:none;transition:border-color var(--transition);background:var(--off-white)}.login-field input:focus{border-color:var(--petrol);background:var(--white)}.login-field input::placeholder{color:var(--grey-light)}.login-password-wrapper{position:relative}.login-password-wrapper input{width:100%;padding-right:48px}.login-password-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--grey-light);padding:4px;display:flex;align-items:center;justify-content:center;transition:color var(--transition)}.login-password-toggle:hover{color:var(--petrol)}.login-error{background:#fef2f0;border:1px solid #fdddd8;color:var(--red);padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;line-height:1.4}.login-btn{padding:14px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:background var(--transition),transform var(--transition);display:flex;align-items:center;justify-content:center;min-height:50px}.login-btn:hover:not(:disabled){background:var(--petrol-dark);transform:translateY(-1px)}.login-btn:disabled{opacity:.7;cursor:not-allowed}.login-btn-spinner{width:22px;height:22px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--white);border-radius:50%;animation:spin .8s linear infinite}.login-link-btn{background:none;border:none;color:var(--petrol);font-size:14px;font-weight:500;cursor:pointer;padding:4px;transition:color var(--transition)}.login-link-btn:hover{color:var(--petrol-dark)}.login-reset-info{font-size:14px;color:var(--grey-light);line-height:1.5}.login-success{text-align:center;padding:20px 0}.login-success-icon{width:56px;height:56px;background:var(--green);color:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;margin:0 auto 16px}.login-success p{color:var(--grey);font-size:15px;line-height:1.5;margin-bottom:20px}@media(max-width:480px){.login-card{padding:36px 24px;border-radius:16px}.login-logo{font-size:30px}}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--white);border-right:1px solid var(--grey-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{height:var(--header-height);padding:0 20px;display:flex;align-items:center;gap:10px;background:var(--petrol);border-bottom:none}.sidebar-logo-img{width:32px;height:auto;flex-shrink:0}.sidebar-logo-text{height:22px;width:auto;flex-shrink:0}.sidebar-header .sidebar-badge{background:#fff3;color:var(--white)}.sidebar-logo{font-size:24px;font-weight:700;color:var(--petrol)}.sidebar-badge{font-size:11px;font-weight:600;color:var(--white);background:var(--petrol);padding:2px 8px;border-radius:10px;text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);color:var(--grey-light);font-size:15px;font-weight:500;transition:all var(--transition)}.sidebar-link:hover{background:var(--off-white);color:var(--grey)}.sidebar-link-active{background:var(--off-white);color:var(--petrol);font-weight:600}.sidebar-icon{font-size:18px;width:24px;text-align:center}.sidebar-footer{padding:16px;border-top:1px solid var(--grey-border);display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-profile{display:flex;align-items:center;gap:10px;min-width:0}.sidebar-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.sidebar-avatar-placeholder{background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.sidebar-profile-info{display:flex;flex-direction:column;min-width:0}.sidebar-profile-name{font-size:13px;font-weight:600;color:var(--grey);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-profile-role{font-size:11px;color:var(--grey-light)}.sidebar-logout{background:none;border:none;color:var(--grey-light);cursor:pointer;padding:8px;border-radius:var(--radius-sm);transition:all var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-logout:hover{background:#fef2f0;color:var(--red)}.main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.main-header{height:var(--header-height);padding:0 32px;display:flex;align-items:center;background:var(--white);border-bottom:1px solid var(--grey-border);position:sticky;top:0;gap:12px;z-index:50}.main-header-logo{display:none;align-items:center;gap:8px}.main-header-logo-img{width:28px;height:auto}.main-header-logo-text{height:18px;width:auto;z-index:50}.main-title{font-size:20px;font-weight:600;color:var(--grey)}.main-content{flex:1;padding:24px 32px}.bottom-nav{display:none}@media(max-width:1024px){.sidebar{display:none}.main{margin-left:0;padding-bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px))}.main-header{padding:env(safe-area-inset-top,0px) 20px 0;height:calc(var(--header-height) + env(safe-area-inset-top,0px));background:var(--petrol)}.main-header .main-title{color:var(--white)}.main-header-logo{display:flex}.main-content{padding:16px 20px;max-width:100vw;overflow-x:hidden}.main{max-width:100vw;overflow-x:hidden}.bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--white);border-top:1px solid var(--grey-border);z-index:100}.bottom-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;color:var(--grey-light);font-size:11px;font-weight:500;transition:color var(--transition);background:none;border:none;cursor:pointer;text-decoration:none}.bottom-nav-item-active{color:var(--petrol);font-weight:700}.bottom-nav-icon{font-size:20px}.bottom-nav-label{font-size:11px}}.nav-badge{font-size:11px;font-weight:700;color:var(--white);background:#e74c3c;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px;margin-left:auto}.bottom-nav-icon{position:relative}.nav-badge-orange{background:#b45309}.nav-badge-small{position:absolute;top:-6px;right:-10px;font-size:9px;min-width:16px;height:16px;border-radius:8px;padding:0 4px;margin-left:0}.bottom-nav-more-wrapper{flex:1;position:relative;display:flex}.more-menu-overlay{display:none}@media(max-width:1024px){.more-menu-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.more-menu{position:absolute;bottom:calc(var(--bottom-nav-height) + 8px);right:0;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--grey-border);min-width:200px;padding:6px 0;z-index:101;animation:more-menu-pop .15s ease}@keyframes more-menu-pop{0%{opacity:0;transform:translateY(8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.more-menu-item{display:flex;align-items:center;gap:10px;padding:10px 16px;color:var(--grey);font-size:14px;font-weight:500;text-decoration:none;transition:background .15s}.more-menu-item:hover{background:var(--off-white)}.more-menu-item-active{color:var(--petrol);font-weight:600;background:var(--off-white)}.more-menu-icon{display:flex;flex-shrink:0}}.page{max-width:1200px}.page-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:var(--white);border-radius:var(--radius);padding:20px 24px;display:flex;align-items:center;gap:16px;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:52px;height:52px;background:var(--off-white);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--petrol)}.stat-info{display:flex;flex-direction:column;gap:2px}.stat-value{font-size:24px;font-weight:700;color:var(--grey)}.stat-label{font-size:13px;color:var(--grey-light);font-weight:500}.stat-sublabel{font-size:11px;color:var(--grey-light);opacity:.7;margin-top:2px}.page-placeholder{background:var(--white);border-radius:var(--radius);padding:64px 32px;text-align:center;box-shadow:var(--shadow)}.placeholder-icon{margin-bottom:16px;color:var(--grey-light);display:flex;justify-content:center}.page-placeholder h3{font-size:20px;font-weight:600;color:var(--grey);margin-bottom:8px}.page-placeholder p{font-size:15px;color:var(--grey-light);max-width:400px;margin:0 auto;line-height:1.5}.placeholder-hint{margin-top:12px!important;font-size:13px!important;font-style:italic;opacity:.7}@media(max-width:1024px){.page-cards{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px;flex-direction:column;text-align:center;gap:8px}.stat-icon{width:44px;height:44px;font-size:22px}.stat-value{font-size:20px}.page-placeholder{padding:48px 24px}}.dashboard-date-picker{margin-bottom:24px;display:flex;flex-direction:column;gap:10px}.dashboard-filters-row{display:flex;align-items:flex-start;gap:16px;flex-wrap:wrap}.dashboard-presets{display:flex;flex-wrap:wrap;gap:6px;flex:1}.dashboard-state-select{padding:6px 32px 6px 14px;border:1.5px solid var(--grey-border);border-radius:20px;background:var(--white);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition);white-space:nowrap;font-family:inherit;outline:none;-moz-appearance:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%23464646' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;flex-shrink:0}.dashboard-state-select:hover{border-color:var(--petrol);color:var(--petrol)}.dashboard-state-select:focus{border-color:var(--petrol);box-shadow:0 0 0 2px #2870831a}.dashboard-preset-btn{padding:6px 14px;border:1.5px solid var(--grey-border);border-radius:20px;background:var(--white);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition);white-space:nowrap}.dashboard-preset-btn:hover{border-color:var(--petrol);color:var(--petrol)}.dashboard-preset-btn-active{background:var(--petrol);border-color:var(--petrol);color:var(--white)}.dashboard-preset-btn-active:hover{background:var(--petrol-dark);border-color:var(--petrol-dark);color:var(--white)}.dashboard-custom-range{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.dashboard-date-input{padding:7px 12px;border:1.5px solid var(--grey-border);border-radius:6px;font-size:13px;color:var(--grey);background:var(--white);outline:none;transition:border-color var(--transition);font-family:inherit}.dashboard-date-input:focus{border-color:var(--petrol)}.dashboard-date-sep{font-size:13px;color:var(--grey-light)}.dashboard-date-apply{padding:7px 16px;border:none;border-radius:6px;background:var(--petrol);color:var(--white);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--transition)}.dashboard-date-apply:hover:not(:disabled){background:var(--petrol-dark)}.dashboard-date-apply:disabled{opacity:.4;cursor:not-allowed}.dashboard-range-label{font-size:12px;color:var(--grey-light);font-weight:500}.dashboard-range-loading{color:var(--petrol);font-style:italic}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.dashboard-card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}.dashboard-card-wide{grid-column:1 / -1}.dashboard-card-title{font-size:15px;font-weight:600;color:var(--grey);margin-bottom:20px}.dashboard-card-loading{display:flex;justify-content:center;padding:32px}.dashboard-card-empty{text-align:center;padding:24px;color:var(--grey-light);font-size:14px}.dashboard-chart{display:flex;flex-direction:column;gap:8px}.dashboard-bar-chart{display:flex;align-items:flex-end;gap:2px;height:160px;padding-bottom:24px;position:relative}.dashboard-bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;position:relative;cursor:default}.dashboard-bar{width:100%;min-height:2px;background:var(--petrol);border-radius:2px 2px 0 0;transition:background var(--transition);opacity:.75}.dashboard-bar-col:hover .dashboard-bar{opacity:1;background:var(--petrol-dark)}.dashboard-bar-label{position:absolute;bottom:0;font-size:9px;color:var(--grey-light);transform:translateY(100%);white-space:nowrap}.dashboard-bar-col .dashboard-bar-label{display:none}.dashboard-bar-label-visible{display:block!important}.dashboard-chart-legend{text-align:center;font-size:12px;color:var(--grey-light);margin-top:4px}.dashboard-horizontal-bars{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.dashboard-hbar-row{display:flex;align-items:center;gap:10px}.dashboard-hbar-label{width:160px;font-size:12px;font-weight:600;color:var(--grey);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-hbar-track{flex:1;height:20px;background:var(--off-white);border-radius:4px;overflow:hidden}.dashboard-hbar-fill{height:100%;background:var(--turquoise);border-radius:4px;min-width:4px;transition:width .4s ease}.dashboard-hbar-value{width:32px;font-size:13px;font-weight:600;color:var(--grey);text-align:right;flex-shrink:0}.dashboard-list{display:flex;flex-direction:column}.dashboard-list-item{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04)}.dashboard-list-item:last-child{border-bottom:none}.dashboard-list-rank{width:24px;height:24px;border-radius:6px;background:var(--off-white);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--grey-light);flex-shrink:0}.dashboard-list-label{flex:1;font-size:13px;color:var(--grey);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-list-value{font-size:13px;font-weight:600;color:var(--petrol);flex-shrink:0}.dashboard-quick-stats{display:flex;flex-direction:column;gap:16px}.dashboard-quick-stat{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--off-white);border-radius:var(--radius-sm)}.dashboard-quick-value{font-size:20px;font-weight:700;color:var(--grey)}.dashboard-quick-label{font-size:13px;color:var(--grey-light);font-weight:500}.dashboard-card-notice{display:flex;gap:12px;padding:16px;background:#f0c73f14;border-radius:var(--radius-sm);border-left:3px solid var(--yellow);color:var(--grey)}.dashboard-card-notice svg{flex-shrink:0;margin-top:1px;color:var(--yellow)}.dashboard-notice-title{font-size:14px;font-weight:600;margin-bottom:4px}.dashboard-notice-text{font-size:13px;color:var(--grey-light);line-height:1.5}@media(max-width:1024px){.dashboard-presets{gap:4px}.dashboard-preset-btn{padding:5px 10px;font-size:12px}.dashboard-filters-row{flex-direction:column}.dashboard-state-select{align-self:flex-start}.dashboard-custom-range{flex-direction:column;align-items:stretch}.dashboard-date-sep{display:none}.dashboard-grid{grid-template-columns:1fr}.dashboard-card{padding:20px 16px}.dashboard-bar-chart{height:120px}.dashboard-quick-stat{padding:10px 12px}.dashboard-quick-value{font-size:18px}}.chat-page{display:flex;height:calc(100vh - var(--header-height));margin:-24px -32px;overflow:hidden}.chat-list{width:360px;flex-shrink:0;background:var(--white);border-right:1px solid var(--grey-border);display:flex;flex-direction:column;overflow:hidden}.chat-list-header{padding:20px 20px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--grey-border);flex-shrink:0}.chat-list-header h3{font-size:18px;font-weight:600;color:var(--grey)}.chat-unread-total{font-size:12px;font-weight:700;color:var(--white);background:var(--petrol);min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 6px}.chat-mark-all-read{background:none;border:1px solid var(--grey-border);border-radius:var(--radius-sm);padding:4px 10px;cursor:pointer;color:var(--grey-light);display:flex;align-items:center;gap:5px;font-size:12px;font-weight:500;white-space:nowrap;transition:all .15s;margin-left:auto}.chat-mark-all-read:hover{background:var(--off-white);color:var(--petrol);border-color:var(--petrol)}.chat-push-hint{display:flex;align-items:center;gap:8px;margin:8px 12px;padding:8px 12px;background:#f0c73f1a;border:1px solid rgba(240,199,63,.3);border-radius:8px;font-size:12px;color:var(--grey);line-height:1.4;flex-shrink:0}.chat-push-hint svg{flex-shrink:0;color:#b8940a}.chat-push-hint a{color:var(--petrol);font-weight:600;text-decoration:none}.chat-push-hint a:hover{text-decoration:underline}.chat-list-toolbar{padding:8px 12px;border-bottom:1px solid var(--grey-border);display:flex;flex-direction:column;gap:8px;flex-shrink:0}.chat-search-wrapper{position:relative;display:flex;align-items:center}.chat-search-icon{position:absolute;left:10px;color:var(--grey-light);pointer-events:none}.chat-search-input{width:100%;padding:8px 30px 8px 32px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);font-size:13px;background:var(--off-white);transition:border-color .15s}.chat-search-input:focus{outline:none;border-color:var(--petrol);background:var(--white)}.chat-search-clear{position:absolute;right:6px;background:none;border:none;font-size:16px;color:var(--grey-light);cursor:pointer;padding:2px 6px}.chat-search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--white);border:1px solid var(--grey-border);border-radius:var(--radius-sm);box-shadow:0 4px 12px #0000001a;z-index:20;max-height:300px;overflow-y:auto;margin-top:4px}.chat-search-suggestion{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 12px;border:none;background:none;cursor:pointer;font-size:13px;text-align:left;transition:background .1s}.chat-search-suggestion:hover{background:var(--off-white)}.chat-suggestion-name{font-weight:600;color:var(--grey)}.chat-suggestion-phone{font-size:12px;color:var(--grey-light);font-family:SF Mono,Fira Code,monospace}.chat-filter-btns{display:flex;gap:4px}.chat-filter-btn{flex:1;padding:6px 8px;border:none;background:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;color:var(--grey-light);cursor:pointer;transition:all .15s}.chat-filter-btn:hover{background:var(--off-white)}.chat-filter-btn-active{background:var(--petrol);color:var(--white)}.chat-filter-btn-active:hover{background:var(--petrol)}.chat-list-items{flex:1;overflow-y:auto}.chat-list-empty{padding:48px 20px;text-align:center;color:var(--grey-light);font-size:14px}.chat-list-loading-more{display:flex;justify-content:center;padding:16px}.chat-list-item{display:flex;align-items:center;gap:12px;padding:14px 20px;width:100%;border:none;background:none;cursor:pointer;text-align:left;transition:background var(--transition);border-bottom:1px solid rgba(0,0,0,.04)}.chat-list-item:hover{background:var(--off-white)}.chat-list-item-active{background:#2870830f}.chat-list-item-active:hover{background:#28708314}.chat-list-item-unread .chat-list-name{font-weight:700}.chat-list-item-unread .chat-list-preview{color:var(--grey);font-weight:500}.chat-list-avatar{width:44px;height:44px;border-radius:50%;background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:600;flex-shrink:0}.chat-list-content{flex:1;min-width:0}.chat-list-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:3px}.chat-list-name{font-size:14px;font-weight:600;color:var(--grey);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-time{font-size:11px;color:var(--grey-light);flex-shrink:0}.chat-list-bottom{display:flex;justify-content:space-between;align-items:center;gap:8px}.chat-list-preview{font-size:13px;color:var(--grey-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-list-draft{color:var(--yellow);font-weight:600}.chat-list-meta{display:flex;align-items:center;gap:6px;flex-shrink:0}.chat-list-unread-dot{width:10px;height:10px;border-radius:50%;background:var(--petrol);flex-shrink:0}.chat-list-read-avatars{display:flex;margin-left:2px}.chat-list-read-avatar{width:20px;height:20px;border-radius:50%;color:var(--white);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:-4px;border:2px solid var(--white);overflow:hidden}.chat-list-read-avatar:first-child{margin-left:0}.chat-list-read-avatar img{width:100%;height:100%;object-fit:cover}.chat-conversation{flex:1;display:flex;flex-direction:column;min-width:0;background:var(--off-white)}.chat-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:var(--grey-light)}.chat-empty-icon{opacity:.3}.chat-empty-state p{font-size:15px}.chat-conv-header{display:flex;align-items:center;gap:12px;padding:12px 20px;background:var(--white);border-bottom:1px solid var(--grey-border);flex-shrink:0}.chat-back-btn{display:none;background:none;border:none;color:var(--petrol);cursor:pointer;padding:4px}.chat-conv-avatar{width:38px;height:38px;border-radius:50%;background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;flex-shrink:0}.chat-conv-info{display:flex;flex-direction:column;min-width:0}.chat-conv-name{font-size:15px;font-weight:600;color:var(--grey)}.chat-conv-detail{font-size:12px;color:var(--grey-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-status-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--grey-border);border-radius:16px;background:none;font-size:12px;font-weight:600;color:var(--grey-light);cursor:pointer;transition:all var(--transition);white-space:nowrap}.chat-status-btn:hover{border-color:var(--petrol);color:var(--petrol)}.chat-status-btn-closed{border-color:var(--green);color:var(--green)}.chat-status-btn-closed:hover{background:#50c8780f}.chat-list-item-closed{opacity:.55}.chat-list-closed-badge{font-size:10px;font-weight:600;color:var(--green);background:#50c8781a;padding:1px 6px;border-radius:4px;flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column}.chat-messages-loading{flex:1;display:flex;align-items:center;justify-content:center}.chat-no-messages{flex:1;display:flex;align-items:center;justify-content:center;color:var(--grey-light);font-size:14px}.chat-load-more{align-self:center;background:none;border:1px solid var(--grey-border);border-radius:16px;padding:6px 16px;font-size:12px;color:var(--grey-light);cursor:pointer;margin-bottom:16px;transition:all var(--transition)}.chat-load-more:hover:not(:disabled){border-color:var(--petrol);color:var(--petrol)}.chat-load-more:disabled{opacity:.5}.chat-date-divider{display:flex;align-items:center;justify-content:center;margin:16px 0 12px}.chat-date-divider span{font-size:11px;font-weight:600;color:var(--grey-light);background:#0000000d;padding:4px 12px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.chat-msg{display:flex;flex-direction:column;margin-bottom:6px;max-width:70%}.chat-msg-user{align-self:flex-start}.chat-msg-admin{align-self:flex-end;align-items:flex-end}.chat-msg-sender{font-size:11px;font-weight:600;margin-bottom:2px;padding:0 4px}.chat-msg-bubble{padding:10px 14px;border-radius:18px;font-size:14px;line-height:1.45;word-break:break-word;white-space:pre-wrap}.chat-msg-user .chat-msg-bubble{background:var(--white);color:var(--grey);border-bottom-left-radius:6px;box-shadow:0 1px 3px #0000000f}.chat-msg-admin .chat-msg-bubble{background:var(--petrol);color:var(--white);border-bottom-right-radius:6px}.chat-msg-time{font-size:10px;color:var(--grey-light);margin-top:2px;padding:0 4px}.chat-input-area{background:var(--white);border-top:1px solid var(--grey-border);flex-shrink:0;padding:12px 20px 8px}.chat-input-bar{display:flex;align-items:flex-end;gap:10px}.chat-input-hint{display:block;font-size:11px;color:var(--grey-light);opacity:.6;margin-top:4px;padding-left:2px}.chat-input{flex:1;padding:10px 16px;border:2px solid var(--grey-border);border-radius:20px;font-size:14px;color:var(--grey);background:var(--off-white);outline:none;resize:none;max-height:120px;line-height:1.4;font-family:inherit;transition:border-color var(--transition)}.chat-input:focus{border-color:var(--petrol);background:var(--white)}.chat-input::placeholder{color:var(--grey-light)}.chat-send-btn{width:42px;height:42px;border:none;border-radius:50%;background:var(--petrol);color:var(--white);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition),opacity var(--transition)}.chat-send-btn:hover:not(:disabled){background:var(--petrol-dark)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}@media(max-width:1024px){.chat-page{margin:-16px -20px;width:calc(100% + 40px);max-width:100vw;height:calc(100vh - var(--header-height) - var(--bottom-nav-height) - env(safe-area-inset-top,0px) - env(safe-area-inset-bottom,0px));overflow:hidden}.chat-list{width:100%;min-width:0;flex-shrink:1;border-right:none;overflow-x:hidden}.chat-list-hidden-mobile,.chat-conversation{display:none}.chat-conversation-visible-mobile,.chat-back-btn{display:flex}.chat-msg{max-width:85%}.chat-conv-header{padding:10px 16px}.chat-conversation{min-width:0;max-width:100%;overflow-x:hidden}.chat-messages{padding:12px 16px;min-width:0;overflow-x:hidden}.chat-msg-bubble{overflow-wrap:break-word;word-break:break-word}.chat-conv-info{max-width:calc(100vw - 120px)}.chat-input-area{padding:10px 16px 6px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px))}.chat-input-hint{display:none}.chat-list-header,.chat-list-toolbar,.chat-list-item{max-width:100%;box-sizing:border-box;overflow:hidden}.chat-list-items{overflow-x:hidden}.chat-search-input{min-width:0}.chat-list-content{overflow:hidden}.chat-input-bar{max-width:100%}}.users-page{max-width:100%}.users-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px;flex-wrap:wrap}.users-toolbar-left{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.users-toolbar-right{display:flex;align-items:center;gap:16px;flex-shrink:0}.users-count{font-size:13px;color:var(--grey-light);font-weight:500;white-space:nowrap}.users-search{position:relative;flex:1;max-width:400px}.users-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--grey-light);pointer-events:none}.users-search-input{width:100%;padding:10px 36px 10px 42px;border:2px solid var(--grey-border);border-radius:var(--radius-sm);font-size:14px;color:var(--grey);background:var(--white);outline:none;transition:border-color var(--transition)}.users-search-input:focus{border-color:var(--petrol)}.users-search-input::placeholder{color:var(--grey-light)}.users-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:20px;color:var(--grey-light);cursor:pointer;padding:4px 8px;line-height:1}.users-search-clear:hover{color:var(--grey)}.users-filter-toggle{display:flex;align-items:center;gap:6px;padding:10px 16px;border:2px solid var(--grey-border);border-radius:var(--radius-sm);background:var(--white);font-size:14px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition);white-space:nowrap;position:relative}.users-filter-toggle:hover{border-color:var(--petrol);color:var(--petrol)}.users-filter-toggle-active{border-color:var(--petrol);color:var(--petrol);background:#2870830a}.users-filter-badge{width:8px;height:8px;background:var(--petrol);border-radius:50%}.users-export-wrapper{position:relative}.users-export-btn{display:flex;align-items:center;gap:6px;padding:10px 18px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition);white-space:nowrap}.users-export-btn:hover{background:var(--petrol-dark)}.users-export-menu{position:absolute;top:calc(100% + 6px);right:0;background:var(--white);border-radius:var(--radius);box-shadow:0 4px 20px #00000026;min-width:240px;z-index:60;overflow:hidden}.users-export-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:14px 18px;background:none;border:none;font-size:14px;font-weight:500;color:var(--grey);cursor:pointer;transition:background var(--transition);text-align:left;flex-wrap:wrap}.users-export-menu-item:hover{background:var(--off-white)}.users-export-menu-item+.users-export-menu-item{border-top:1px solid var(--grey-border)}.users-export-menu-hint{width:100%;font-size:12px;color:var(--grey-light);font-weight:400;margin-left:24px}.users-filters{background:var(--white);border-radius:var(--radius);padding:20px 24px;margin-bottom:16px;box-shadow:var(--shadow);animation:filterSlideDown .2s ease}@keyframes filterSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.users-filter-row{display:flex;gap:16px;flex-wrap:wrap}.users-filter-field{display:flex;flex-direction:column;gap:4px;min-width:160px;flex:1}.users-filter-field label{font-size:12px;font-weight:600;color:var(--grey-light);text-transform:uppercase;letter-spacing:.3px}.users-filter-field input,.users-filter-field select{padding:8px 12px;border:1.5px solid var(--grey-border);border-radius:6px;font-size:13px;color:var(--grey);background:var(--off-white);outline:none;transition:border-color var(--transition)}.users-filter-field input:focus,.users-filter-field select:focus{border-color:var(--petrol);background:var(--white)}.users-clear-filters{margin-top:12px;background:none;border:none;color:var(--petrol);font-size:13px;font-weight:500;cursor:pointer;padding:0}.users-clear-filters:hover{text-decoration:underline}.users-mobile-sort{display:none}.users-table-wrapper{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow-x:auto;-webkit-overflow-scrolling:touch}.users-table{width:100%;border-collapse:collapse;font-size:13px;white-space:nowrap}.users-table thead{position:sticky;top:0;z-index:10}.users-table th{background:var(--off-white);padding:12px 16px;text-align:left;font-weight:600;font-size:12px;color:var(--grey-light);text-transform:uppercase;letter-spacing:.3px;cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:1px solid var(--grey-border);transition:color var(--transition)}.users-table th:hover{color:var(--petrol)}.users-table td{padding:11px 16px;color:var(--grey);border-bottom:1px solid var(--grey-border)}.users-table tbody tr{transition:background var(--transition)}.users-table tbody tr:hover{background:#28708308}.users-table tbody tr:last-child td{border-bottom:none}.users-mono{font-family:SF Mono,Fira Code,monospace;font-size:12px;letter-spacing:-.3px}.users-empty{text-align:center;padding:48px 16px!important;color:var(--grey-light);font-size:14px}.sort-icon{font-size:13px;margin-left:4px;color:var(--petrol)}.sort-icon-inactive{color:var(--grey-light);opacity:.4}.users-cards{display:none}.users-cards-empty{text-align:center;padding:48px 16px;color:var(--grey-light);font-size:14px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow)}.user-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.user-card-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--grey-border)}.user-card-avatar{width:40px;height:40px;border-radius:50%;background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;flex-shrink:0}.user-card-name{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-card-fullname{font-size:15px;font-weight:600;color:var(--grey);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-phone{font-size:12px;color:var(--grey-light);font-family:SF Mono,Fira Code,monospace}.user-card-state-badge{font-size:11px;font-weight:600;color:var(--petrol);background:#28708314;padding:4px 10px;border-radius:12px;flex-shrink:0}.user-card-details{padding:4px 16px 12px}.user-card-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04)}.user-card-row:last-child{border-bottom:none}.user-card-label{font-size:12px;color:var(--grey-light);font-weight:500}.user-card-value{font-size:13px;color:var(--grey);font-weight:500;text-align:right}.users-table-row-clickable{cursor:pointer}.users-table-row-clickable:hover{background:#28708308}.users-table-row-expanded{background:#2870830a!important}.users-changes-row td{padding:0!important;border-bottom:1px solid var(--grey-border)}.user-changes-panel{padding:16px 24px 20px;background:var(--off-white);border-top:1px solid var(--grey-border)}.user-changes-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--grey);margin-bottom:12px}.user-changes-title svg{color:var(--petrol)}.user-changes-loading{display:flex;justify-content:center;padding:16px}.user-changes-empty{font-size:13px;color:var(--grey-light);padding:4px 0}.user-changes-timeline{display:flex;flex-direction:column;gap:0;padding-left:8px;border-left:2px solid var(--grey-border)}.user-change-entry{display:flex;gap:12px;padding:10px 0;position:relative}.user-change-entry:first-child{padding-top:0}.user-change-dot{width:10px;height:10px;border-radius:50%;background:var(--petrol);flex-shrink:0;margin-top:3px;margin-left:-14px;border:2px solid var(--off-white)}.user-change-content{flex:1;min-width:0}.user-change-date{font-size:11px;font-weight:600;color:var(--grey-light);display:block;margin-bottom:6px}.user-change-fields{display:flex;flex-direction:column;gap:4px}.user-change-field{display:flex;align-items:center;gap:8px;font-size:13px;flex-wrap:wrap}.user-change-field-name{font-weight:600;color:var(--grey);min-width:80px}.user-change-old{color:var(--red);text-decoration:line-through;opacity:.7}.user-change-arrow{color:var(--grey-light);flex-shrink:0}.user-change-new{color:var(--green);font-weight:500}.user-card-chevron{flex-shrink:0;color:var(--grey-light);transition:transform var(--transition)}.user-card-chevron-open{transform:rotate(180deg)}.user-card-changes{padding:16px;background:var(--off-white);border-top:1px solid var(--grey-border)}.user-card-expanded{border:1px solid rgba(40,112,131,.15)}.user-changes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.user-changes-header .user-changes-title{margin-bottom:0}.user-delete-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--red);border-radius:6px;background:none;font-size:12px;font-weight:600;color:var(--red);cursor:pointer;transition:all var(--transition)}.user-delete-btn:hover{background:var(--red);color:var(--white)}.user-delete-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.user-delete-modal{background:var(--white);border-radius:var(--radius);padding:28px;max-width:440px;width:100%;box-shadow:0 8px 32px #0003}.user-delete-modal-title{font-size:18px;font-weight:600;color:var(--grey);margin-bottom:12px}.user-delete-modal-text{font-size:14px;color:var(--grey);line-height:1.5;margin-bottom:8px}.user-delete-modal-detail{font-size:13px;color:var(--grey-light);line-height:1.5;margin-bottom:16px}.user-delete-modal-error{font-size:13px;color:var(--red);background:#e8746114;padding:10px 14px;border-radius:6px;margin-bottom:16px}.user-delete-modal-actions{display:flex;justify-content:flex-end;gap:10px}.user-delete-modal-cancel{padding:10px 20px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);background:none;font-size:14px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition)}.user-delete-modal-cancel:hover:not(:disabled){border-color:var(--grey)}.user-delete-modal-cancel:disabled{opacity:.5}.user-delete-modal-confirm{padding:10px 20px;border:none;border-radius:var(--radius-sm);background:var(--red);font-size:14px;font-weight:600;color:var(--white);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;min-width:140px}.user-delete-modal-confirm:hover:not(:disabled){background:#d4553f}.user-delete-modal-confirm:disabled{opacity:.7;cursor:not-allowed}.users-pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:20px}.users-page-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1.5px solid var(--grey-border);border-radius:8px;background:var(--white);color:var(--grey);font-size:16px;cursor:pointer;transition:all var(--transition)}.users-page-btn:hover:not(:disabled){border-color:var(--petrol);color:var(--petrol)}.users-page-btn:disabled{opacity:.3;cursor:not-allowed}.users-page-info{font-size:13px;color:var(--grey-light);font-weight:500;padding:0 12px}.users-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.users-loading p{font-size:14px;color:var(--grey-light)}.users-error{background:var(--white);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow)}.users-error p{color:var(--red);font-size:15px;margin-bottom:16px}.users-retry-btn{padding:10px 24px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer}.users-retry-btn:hover{background:var(--petrol-dark)}@media(max-width:1024px){.users-toolbar{flex-direction:column;align-items:stretch}.users-toolbar-left{flex-direction:row}.users-search{max-width:100%;flex:1}.users-toolbar-right{justify-content:space-between}.users-filter-row{flex-direction:column;gap:12px}.users-filter-field{min-width:auto}.users-table-wrapper{display:none}.users-cards{display:flex;flex-direction:column;gap:12px}.users-mobile-sort{display:flex;gap:8px;margin-bottom:12px}.users-mobile-sort-select{flex:1;padding:8px 12px;border:1.5px solid var(--grey-border);border-radius:6px;font-size:13px;font-weight:500;color:var(--grey);background:var(--white);outline:none}.users-mobile-sort-select:focus{border-color:var(--petrol)}.users-mobile-sort-dir{padding:8px 14px;border:1.5px solid var(--grey-border);border-radius:6px;font-size:13px;font-weight:500;color:var(--petrol);background:var(--white);cursor:pointer;white-space:nowrap;transition:all var(--transition)}.users-mobile-sort-dir:hover{border-color:var(--petrol)}.users-filters{padding:16px}.users-export-btn svg{display:none}}.settings-container{max-width:640px;display:flex;flex-direction:column;gap:24px}.settings-card{background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}.settings-section-title{font-size:18px;font-weight:600;color:var(--grey);margin-bottom:24px}.settings-avatar-section{display:flex;flex-direction:column;align-items:center;margin-bottom:28px}.settings-avatar-wrapper{position:relative;width:96px;height:96px;border-radius:50%;cursor:pointer;overflow:hidden}.settings-avatar{width:100%;height:100%;border-radius:50%;object-fit:cover}.settings-avatar-placeholder{background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:600}.settings-avatar-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition);border-radius:50%}.settings-avatar-wrapper:hover .settings-avatar-overlay{opacity:1}.settings-file-input{display:none}.settings-avatar-hint{font-size:13px;color:var(--grey-light);margin-top:8px}.settings-upload-spinner{width:24px;height:24px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.settings-fields{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px}.settings-field{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.settings-fields .settings-field{margin-bottom:0}.settings-field label{font-size:13px;font-weight:600;color:var(--grey);text-transform:uppercase;letter-spacing:.5px}.settings-field-hint{font-size:13px;color:var(--grey-light);margin-bottom:8px}.settings-field input{padding:12px 16px;border:2px solid var(--grey-border);border-radius:var(--radius-sm);font-size:15px;color:var(--grey);outline:none;transition:border-color var(--transition);background:var(--off-white)}.settings-field input:focus{border-color:var(--petrol);background:var(--white)}.settings-colors{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.settings-color-btn{width:40px;height:40px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all var(--transition);position:relative}.settings-color-btn:hover{transform:scale(1.1)}.settings-color-btn-active{border-color:var(--grey);box-shadow:0 0 0 2px var(--white),0 0 0 4px var(--grey)}.settings-color-preview{margin-top:8px}.settings-color-bubble{display:inline-block;padding:10px 18px;border-radius:18px 18px 6px;color:var(--white);font-size:14px;font-weight:500}.settings-actions{margin-top:8px}.settings-save-btn{padding:12px 32px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;min-width:140px;min-height:46px}.settings-save-btn:hover:not(:disabled){background:var(--petrol-dark)}.settings-save-btn:disabled{opacity:.7;cursor:not-allowed}.settings-save-btn-success{background:var(--green)!important}.settings-save-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.settings-card-info{padding:24px 32px}.settings-info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--grey-border)}.settings-info-row:last-child{border-bottom:none}.settings-info-label{font-size:14px;color:var(--grey-light);font-weight:500}.settings-info-value{font-size:14px;color:var(--grey);font-weight:500}.settings-status{font-size:13px;font-weight:600;padding:4px 12px;border-radius:12px;background:#f0f0f0;color:var(--grey-light)}.settings-status-active{background:#e8f5e9;color:var(--green)}.settings-push-status{font-size:12px;font-weight:600;padding:3px 10px;border-radius:10px}.settings-push-status-active{background:#e8f5e9;color:var(--green)}.settings-push-status-off{background:#f5f5f5;color:var(--grey-light)}.settings-push-status-denied{background:#fce4ec;color:#c4493a}.settings-push-status-warn{background:#f0c73f26;color:#b8940a}.settings-push-hint{font-size:13px;color:var(--grey-light);line-height:1.5;margin-top:12px;padding:0 4px}.settings-push-action{margin-top:12px}.settings-push-enable-btn{padding:8px 20px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background var(--transition)}.settings-push-enable-btn:hover{background:var(--petrol-dark)}.settings-push-disable-btn{padding:8px 20px;background:none;border:1px solid var(--grey-border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition)}.settings-push-disable-btn:hover{border-color:#c4493a;color:#c4493a}.settings-pw-rules{display:flex;flex-direction:column;gap:6px;margin-bottom:20px;padding:14px 16px;background:var(--off-white);border-radius:var(--radius-sm)}.settings-pw-rule{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--grey-light);transition:color .2s}.settings-pw-rule svg{flex-shrink:0;color:var(--grey-border);transition:color .2s}.settings-pw-rule-met{color:var(--green)}.settings-pw-rule-met svg{color:var(--green)}.settings-pw-error{font-size:13px;color:#c4493a;background:#fce4ec;padding:10px 14px;border-radius:var(--radius-sm);margin-bottom:16px}.settings-disk-bar-wrapper{margin-top:8px;display:flex;flex-direction:column;gap:4px}.settings-disk-bar-track{height:8px;background:var(--off-white);border-radius:4px;overflow:hidden;width:100%}.settings-disk-bar-fill{height:100%;border-radius:4px;transition:width .4s ease}.settings-disk-green{background:#4caf50}.settings-disk-yellow{background:#ff9800}.settings-disk-red{background:#f44336}.server-info-wrapper{position:relative;display:flex;justify-content:flex-end}.server-info-btn{display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--grey-border);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px;font-weight:500;color:var(--grey-light);cursor:pointer;transition:all var(--transition)}.server-info-btn:hover{color:var(--petrol);border-color:var(--petrol)}.server-info-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:59}.server-info-popup{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--grey-border);min-width:280px;z-index:60;animation:serverInfoPop .15s ease}@keyframes serverInfoPop{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.server-info-popup-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--grey-border)}.server-info-popup-title{font-size:14px;font-weight:600;color:var(--grey)}.server-info-popup-close{background:none;border:none;font-size:20px;color:var(--grey-light);cursor:pointer;padding:0 4px;line-height:1}.server-info-popup-close:hover{color:var(--grey)}.server-info-popup-content{padding:14px 16px}.settings-install-desc{font-size:13px;color:var(--grey-light);line-height:1.5;margin-bottom:12px}.settings-install-steps{margin-top:8px}.settings-install-step-title{font-size:13px;font-weight:600;color:var(--grey);margin-bottom:8px}.settings-install-list{font-size:13px;color:var(--grey-light);line-height:1.8;padding-left:20px;margin:0}.settings-install-list li{padding-left:4px}@media(max-width:1024px){.settings-card{padding:24px 20px}.settings-fields{grid-template-columns:1fr}}.termine-page{max-width:900px}.termine-tabs{display:flex;gap:4px;background:var(--white);border-radius:var(--radius);padding:4px;box-shadow:var(--shadow);margin-bottom:20px}.termine-tab{flex:1;padding:12px 20px;border:none;background:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--grey-light);cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;gap:8px}.termine-tab:hover{color:var(--grey);background:var(--off-white)}.termine-tab-active{background:var(--petrol);color:var(--white)}.termine-tab-active:hover{background:var(--petrol-dark);color:var(--white)}.termine-tab-badge{font-size:11px;font-weight:700;background:#ffffff40;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;padding:0 6px}.termine-tab:not(.termine-tab-active) .termine-tab-badge{background:var(--petrol);color:var(--white)}.termine-pending-badge{display:inline-flex;align-items:center;margin-left:8px;padding:2px 8px;font-size:11px;font-weight:700;color:#b45309;background:#fef3c7;border-radius:10px}.termine-content{animation:termineSlideIn .2s ease}@keyframes termineSlideIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.termine-filters{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.termine-filter-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:1.5px solid var(--grey-border);border-radius:20px;background:var(--white);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition)}.termine-filter-btn:hover{border-color:var(--petrol);color:var(--petrol)}.termine-filter-btn-active{background:var(--petrol);border-color:var(--petrol);color:var(--white)}.termine-filter-btn-active:hover{background:var(--petrol-dark);border-color:var(--petrol-dark)}.termine-filter-count{font-size:11px;font-weight:700;opacity:.7}.termine-list{display:flex;flex-direction:column;gap:12px}.termine-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow var(--transition)}.termine-card:hover{box-shadow:var(--shadow-lg)}.termine-card-cancelled{opacity:.6}.termine-card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px 0;gap:12px}.termine-card-type{display:flex;gap:10px;align-items:flex-start;min-width:0}.termine-card-type-icon{font-size:20px;flex-shrink:0;margin-top:1px}.termine-card-type h4{font-size:15px;font-weight:600;color:var(--grey);margin:0}.termine-card-type-desc{font-size:13px;color:var(--grey-light);margin-top:2px;line-height:1.4}.termine-status-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px;flex-shrink:0;white-space:nowrap}.termine-status-requested{background:#f0c73f26;color:#b8940a}.termine-status-confirmed{background:#50c8781f;color:#2d8f4e}.termine-status-rejected{background:#e874611f;color:#c4493a}.termine-ws-badge{font-size:11px;font-weight:600;padding:4px 10px;border-radius:12px;flex-shrink:0;white-space:nowrap}.termine-ws-draft{background:#9a9a9a1f;color:var(--grey-light)}.termine-ws-published{background:#2870831a;color:var(--petrol)}.termine-ws-cancelled{background:#e874611f;color:#c4493a}.termine-card-body{padding:12px 20px}.termine-card-info{display:flex;flex-direction:column;gap:0}.termine-card-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.04)}.termine-card-row:last-child{border-bottom:none}.termine-card-label{font-size:12px;color:var(--grey-light);font-weight:500}.termine-card-value{font-size:13px;color:var(--grey);font-weight:500;text-align:right;max-width:60%;word-break:break-word}.termine-card-actions{display:flex;gap:8px;padding:12px 20px 16px;flex-wrap:wrap}.termine-action-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all var(--transition);border:1px solid transparent}.termine-action-chat{background:none;border-color:var(--petrol);color:var(--petrol)}.termine-action-chat:hover{background:#2870830f}.termine-action-confirm{background:var(--green);color:var(--white);border-color:var(--green)}.termine-action-confirm:hover{background:#45b56a}.termine-action-reject{background:none;border-color:var(--red);color:var(--red)}.termine-action-reject:hover{background:#e874610f}.termine-action-edit{background:none;border-color:var(--grey-border);color:var(--grey)}.termine-action-edit:hover{border-color:var(--petrol);color:var(--petrol)}.termine-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px}.termine-loading p{font-size:14px;color:var(--grey-light)}.termine-empty{background:var(--white);border-radius:var(--radius);padding:64px 32px;text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:12px}.termine-empty-icon{opacity:.3;color:var(--grey-light)}.termine-empty p{font-size:15px;color:var(--grey-light)}.termine-toolbar{display:flex;justify-content:flex-end;margin-bottom:16px}.termine-create-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition)}.termine-create-btn:hover{background:var(--petrol-dark)}.termine-back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:none;border:1.5px solid var(--grey-border);border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;margin-bottom:20px;transition:all var(--transition)}.termine-back-btn:hover{border-color:var(--petrol);color:var(--petrol)}.termine-detail-header{background:var(--white);border-radius:var(--radius);padding:20px 24px;box-shadow:var(--shadow);margin-bottom:16px}.termine-detail-header h3{font-size:18px;font-weight:600;color:var(--grey);margin-bottom:4px}.termine-detail-header p{font-size:13px;color:var(--grey-light);line-height:1.5}.termine-registrations{display:flex;flex-direction:column;gap:8px}.termine-reg-card{background:var(--white);border-radius:var(--radius-sm);padding:14px 20px;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.termine-reg-info{display:flex;align-items:center;gap:10px}.termine-reg-name{font-size:14px;font-weight:600;color:var(--grey)}.termine-reg-actions{display:flex;gap:6px;flex-wrap:wrap}.termine-form-card{background:var(--white);border-radius:var(--radius);padding:24px 28px;box-shadow:var(--shadow)}.termine-form-card h3{font-size:18px;font-weight:600;color:var(--grey);margin-bottom:24px}.termine-form-field{margin-bottom:18px}.termine-form-field label{display:block;font-size:12px;font-weight:600;color:var(--grey-light);text-transform:uppercase;letter-spacing:.3px;margin-bottom:6px}.termine-form-field input,.termine-form-field textarea,.termine-form-field select{width:100%;padding:10px 14px;border:1.5px solid var(--grey-border);border-radius:var(--radius-sm);font-size:14px;color:var(--grey);background:var(--off-white);outline:none;transition:border-color var(--transition),background var(--transition)}.termine-form-field input:focus,.termine-form-field textarea:focus,.termine-form-field select:focus{border-color:var(--petrol);background:var(--white)}.termine-form-field textarea{resize:vertical;font-family:inherit;line-height:1.5}.termine-form-row{display:flex;gap:16px}.termine-form-row .termine-form-field{flex:1}.termine-form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:28px;padding-top:20px;border-top:1px solid var(--grey-border)}.termine-form-cancel{padding:10px 20px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);background:none;font-size:14px;font-weight:500;color:var(--grey);cursor:pointer;transition:all var(--transition)}.termine-form-cancel:hover:not(:disabled){border-color:var(--grey)}.termine-form-submit{padding:10px 24px;border:none;border-radius:var(--radius-sm);background:var(--petrol);font-size:14px;font-weight:600;color:var(--white);cursor:pointer;transition:background var(--transition)}.termine-form-submit:hover:not(:disabled){background:var(--petrol-dark)}.termine-form-submit:disabled{opacity:.5;cursor:not-allowed}.termine-hint{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:#f0c73f1a;border:1px solid rgba(240,199,63,.3);border-radius:var(--radius-sm);margin-bottom:16px;font-size:13px;color:var(--grey);line-height:1.5}.termine-hint-icon{flex-shrink:0;font-size:16px;margin-top:1px}.termine-types-list{display:flex;flex-direction:column;gap:10px}.termine-type-card{background:var(--white);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow);transition:box-shadow var(--transition)}.termine-type-card:hover{box-shadow:var(--shadow-lg)}.termine-type-card-inactive{opacity:.55}.termine-type-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:6px}.termine-type-name{display:flex;align-items:center;gap:8px}.termine-type-name h4{font-size:15px;font-weight:600;color:var(--grey);margin:0}.termine-type-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px}.termine-type-active{background:#50c8781f;color:#2d8f4e}.termine-type-inactive-badge{background:#9a9a9a1f;color:var(--grey-light)}.termine-type-order{font-size:12px;font-weight:600;color:var(--grey-light);background:var(--off-white);padding:2px 8px;border-radius:6px}.termine-type-desc{font-size:13px;color:var(--grey-light);line-height:1.5;margin-bottom:10px}.termine-action-toggle{background:none;border-color:var(--grey-border);color:var(--grey-light)}.termine-action-toggle:hover{border-color:var(--petrol);color:var(--petrol)}.termine-import-btn{margin-top:8px;padding:10px 24px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background var(--transition)}.termine-import-btn:hover:not(:disabled){background:var(--petrol-dark)}.termine-import-btn:disabled{opacity:.6;cursor:not-allowed}.termine-empty h3{font-size:17px;font-weight:600;color:var(--grey)}@media(max-width:1024px){.termine-page{max-width:100%}.termine-filters{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.termine-filter-btn{flex-shrink:0;padding:6px 12px;font-size:12px}.termine-card-header{padding:14px 16px 0}.termine-card-body{padding:10px 16px}.termine-card-actions{padding:10px 16px 14px}.termine-form-row{flex-direction:column;gap:0}.termine-form-card{padding:20px}.termine-reg-card{flex-direction:column;align-items:flex-start}.termine-detail-header{padding:16px 20px}}.termine-user-link{background:none;border:none;padding:0;font:inherit;color:var(--petrol);font-weight:600;cursor:pointer;text-decoration:underline;text-decoration-color:transparent;transition:text-decoration-color .15s}.termine-user-link:hover{text-decoration-color:var(--petrol)}.termine-user-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;animation:termineOverlayIn .15s ease}@keyframes termineOverlayIn{0%{opacity:0}to{opacity:1}}.termine-user-modal{background:var(--white);border-radius:var(--radius);box-shadow:0 20px 60px #0003;width:420px;max-width:calc(100vw - 32px);max-height:calc(100vh - 64px);overflow-y:auto;animation:termineModalIn .2s ease}@keyframes termineModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.termine-user-modal-header{display:flex;align-items:center;gap:12px;padding:20px 20px 16px;border-bottom:1px solid #f0f0f0;position:relative}.termine-user-modal-header h3{margin:0;font-size:16px;font-weight:700;color:var(--grey)}.termine-user-modal-avatar{width:44px;height:44px;border-radius:50%;background:var(--petrol);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px;flex-shrink:0}.termine-user-modal-phone{font-size:13px;color:var(--grey-light);font-family:SF Mono,Fira Code,monospace}.termine-user-modal-close{position:absolute;top:12px;right:12px;background:none;border:none;font-size:22px;color:var(--grey-light);cursor:pointer;line-height:1;padding:4px}.termine-user-modal-close:hover{color:var(--grey)}.termine-user-modal-body{padding:16px 20px}.termine-user-modal-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #f8f8f8;font-size:14px}.termine-user-modal-row:last-child{border-bottom:none}.termine-user-modal-label{color:var(--grey-light);font-weight:500}.termine-user-modal-actions{padding:12px 20px 20px;display:flex;gap:8px}.push-page{max-width:700px;display:flex;flex-direction:column;gap:20px}.push-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.push-card-title{font-size:16px;font-weight:700;color:var(--grey);margin-bottom:20px}.push-field{margin-bottom:16px;position:relative}.push-field label{display:block;font-size:13px;font-weight:600;color:var(--grey);margin-bottom:6px}.push-field input,.push-field textarea,.push-field select{width:100%;padding:10px 12px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s}.push-field input:focus,.push-field textarea:focus,.push-field select:focus{outline:none;border-color:var(--petrol)}.push-field textarea{resize:vertical;min-height:60px}.push-field-hint{font-size:12px;color:var(--grey-light);margin-top:6px;line-height:1.4}.push-field-hint code{background:#0000000d;padding:1px 5px;border-radius:3px;font-size:11px}.push-field-count{position:absolute;bottom:8px;right:12px;font-size:11px;color:var(--grey-light)}.push-field-row{display:flex;gap:12px;margin-bottom:16px}.push-field-row .push-field{flex:1;margin-bottom:0}.push-target-btns{display:flex;flex-wrap:wrap;gap:6px}.push-target-btn{padding:8px 14px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);background:var(--white);font-size:13px;font-weight:500;color:var(--grey);cursor:pointer;transition:all .15s}.push-target-btn:hover{border-color:var(--petrol);color:var(--petrol)}.push-target-btn-active{background:var(--petrol);border-color:var(--petrol);color:var(--white)}.push-target-btn-active:hover{background:var(--petrol-dark);border-color:var(--petrol-dark);color:var(--white)}.push-preview{margin-bottom:16px}.push-preview-label{font-size:12px;color:var(--grey-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;display:block}.push-preview-card{display:flex;gap:12px;align-items:flex-start;background:var(--off-white);border-radius:var(--radius-sm);padding:14px;border:1px solid var(--grey-border)}.push-preview-icon{color:var(--petrol);flex-shrink:0;margin-top:2px}.push-preview-card strong{display:block;font-size:14px;margin-bottom:4px}.push-preview-card p{font-size:13px;color:var(--grey-light);line-height:1.4}.push-result{padding:12px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px}.push-result-success{background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.push-result-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.push-send-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:15px;font-weight:600;cursor:pointer;transition:background .15s}.push-send-btn:hover:not(:disabled){background:var(--petrol-dark)}.push-send-btn:disabled{opacity:.5;cursor:not-allowed}.push-log-empty{text-align:center;color:var(--grey-light);padding:20px;font-size:14px}.push-log-list{display:flex;flex-direction:column;gap:1px;background:var(--grey-border);border-radius:var(--radius-sm);overflow:hidden}.push-log-item{background:var(--white);padding:14px 16px}.push-log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.push-log-header strong{font-size:14px}.push-log-date{font-size:12px;color:var(--grey-light);white-space:nowrap}.push-log-body{font-size:13px;color:var(--grey-light);margin-bottom:8px;line-height:1.4}.push-log-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px}.push-log-target{color:var(--petrol);font-weight:600}.push-log-stats{color:var(--grey-light)}.push-log-failed{color:var(--red)}@media(max-width:768px){.push-target-btns{flex-direction:column}.push-field-row{flex-direction:column;gap:0}.push-field-row .push-field{margin-bottom:16px}.push-log-header{flex-direction:column;align-items:flex-start;gap:4px}}.ann-page{max-width:800px}.ann-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.ann-title{font-size:18px;font-weight:700;color:var(--grey);margin-bottom:4px}.ann-subtitle{font-size:13px;color:var(--grey-light);line-height:1.5}.ann-create-btn{padding:10px 20px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.ann-create-btn:hover{background:var(--petrol-dark)}.ann-form-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin-bottom:24px}.ann-form-title{font-size:16px;font-weight:700;color:var(--grey);margin-bottom:20px}.ann-field{margin-bottom:16px}.ann-field label{display:block;font-size:13px;font-weight:600;color:var(--grey);margin-bottom:6px}.ann-field input,.ann-field textarea,.ann-field select{width:100%;padding:10px 12px;border:1px solid var(--grey-border);border-radius:var(--radius-sm);font-size:14px;transition:border-color .15s}.ann-field input:focus,.ann-field textarea:focus,.ann-field select:focus{outline:none;border-color:var(--petrol)}.ann-field textarea{resize:vertical;min-height:60px}.ann-field-hint{font-size:12px;color:var(--grey-light);margin-top:4px;display:block}.ann-field-row{display:flex;gap:16px}.ann-field-row .ann-field{flex:1}.ann-preview{margin-bottom:20px}.ann-preview-label{display:block;font-size:12px;color:var(--grey-light);font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.ann-preview-card{padding:14px 16px;border-radius:var(--radius-sm);line-height:1.5}.ann-preview-card strong{display:block;font-size:14px;margin-bottom:4px}.ann-preview-card p{font-size:13px;opacity:.85}.ann-form-actions{display:flex;justify-content:flex-end;gap:12px}.ann-cancel-btn{padding:10px 20px;background:var(--off-white);border:1px solid var(--grey-border);border-radius:var(--radius-sm);font-size:14px;font-weight:500;color:var(--grey);cursor:pointer;transition:all .15s}.ann-cancel-btn:hover{background:var(--grey-border)}.ann-save-btn{padding:10px 20px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s}.ann-save-btn:hover:not(:disabled){background:var(--petrol-dark)}.ann-save-btn:disabled{opacity:.5;cursor:not-allowed}.ann-empty{text-align:center;color:var(--grey-light);padding:40px;font-size:14px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow)}.ann-list{display:flex;flex-direction:column;gap:12px}.ann-item{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:transform var(--transition),box-shadow var(--transition)}.ann-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.ann-item-inactive{opacity:.55}.ann-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.ann-item-meta{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.ann-type-badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}.ann-visibility-badge{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;background:var(--off-white);color:var(--grey);border:1px solid var(--grey-border)}.ann-status-badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}.ann-status-inactive{background:#fee2e2;color:#991b1b}.ann-status-expired{background:#fef3c7;color:#92400e}.ann-priority-badge{font-size:11px;color:var(--grey-light);font-weight:500}.ann-item-actions{display:flex;gap:4px}.ann-action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--off-white);border-radius:var(--radius-sm);cursor:pointer;font-size:14px;transition:background .15s}.ann-action-btn:hover{background:var(--grey-border)}.ann-action-delete:hover{background:#fee2e2}.ann-item-title{font-size:15px;font-weight:600;color:var(--grey);margin-bottom:6px}.ann-item-content{font-size:13px;color:var(--grey-light);line-height:1.5;margin-bottom:12px}.ann-item-footer{display:flex;gap:20px;font-size:12px;color:var(--grey-light)}@media(max-width:768px){.ann-header{flex-direction:column}.ann-field-row{flex-direction:column;gap:0}.ann-item-header{flex-direction:column;align-items:flex-start;gap:8px}.ann-item-actions{align-self:flex-end}}:root{--petrol: #287083;--petrol-dark: #1e5663;--turquoise: #8ABFC7;--yellow: #F0C73F;--off-white: #F7F4EF;--grey: #464646;--grey-light: #9a9a9a;--grey-border: #e5e5e5;--white: #ffffff;--red: #E87461;--green: #50C878;--sidebar-width: 260px;--header-height: 64px;--bottom-nav-height: 64px;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 24px rgba(0, 0, 0, .12);--transition: .2s ease}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Barlow,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--off-white);color:var(--grey);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media(max-width:1024px){html,body{overflow-x:hidden;max-width:100vw}}@media(max-width:1024px){table{display:block;overflow-x:auto;max-width:100%}pre,code{overflow-x:auto;max-width:100%}img{max-width:100%;height:auto}}input,button,textarea,select{font-family:inherit}a{text-decoration:none;color:inherit}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--off-white)}.loading-spinner{width:40px;height:40px;border:3px solid var(--grey-border);border-top-color:var(--petrol);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--grey-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--grey)}.push-banner{background:#fffbeb;border-bottom:1px solid #fde68a;padding:10px 16px;z-index:200;flex-shrink:0}.push-banner-content{display:flex;align-items:center;gap:10px;max-width:1000px;margin:0 auto;font-size:13px}.push-banner-content>svg{flex-shrink:0;color:#b45309}.push-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.push-banner-text strong{font-weight:700;color:#92400e}.push-banner-text span{color:#78350f}.push-banner-ios-icon{display:inline-flex;vertical-align:middle;color:#2563eb}.push-banner-allow{padding:6px 14px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.push-banner-allow:hover{background:var(--petrol-dark)}.push-banner-dismiss{background:none;border:none;font-size:18px;color:#b45309;cursor:pointer;padding:4px;line-height:1;opacity:.6}.push-banner-dismiss:hover{opacity:1}.install-banner{position:fixed;bottom:16px;left:16px;right:16px;z-index:300;animation:install-banner-slide-up .3s ease}@media(max-width:1024px){.install-banner{bottom:calc(var(--bottom-nav-height) + env(safe-area-inset-bottom,0px) + 12px)}}@media(min-width:1025px){.install-banner{left:auto;right:24px;bottom:24px;max-width:420px}}@keyframes install-banner-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.install-banner-content{display:flex;align-items:center;gap:10px;padding:14px 16px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--grey-border);font-size:13px}.install-banner-content>svg{flex-shrink:0;color:var(--petrol)}.install-banner-text{flex:1;display:flex;flex-direction:column;gap:2px}.install-banner-text strong{font-weight:700;color:var(--grey)}.install-banner-text span{color:var(--grey-light)}.install-banner-ios-icon{display:inline-flex;vertical-align:middle;color:#2563eb}.install-banner-btn{padding:6px 14px;background:var(--petrol);color:var(--white);border:none;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s}.install-banner-btn:hover{background:var(--petrol-dark)}.install-banner-dismiss{background:none;border:none;font-size:18px;color:var(--grey-light);cursor:pointer;padding:4px;line-height:1;opacity:.6}.install-banner-dismiss:hover{opacity:1}
