.login-page{align-items:center;background:linear-gradient(135deg,#0f172a,#1e3a5f 50%,#0f172a);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-bg{inset:0;pointer-events:none;position:absolute}.login-bg-shape{border-radius:50%;filter:blur(80px);opacity:.15;position:absolute}.shape-1{background:#3b82f6;height:400px;right:-100px;top:-100px;width:400px}.shape-2{background:#8b5cf6;bottom:-50px;height:300px;left:-50px;width:300px}.shape-3{background:#06b6d4;height:200px;left:50%;top:50%;transform:translate(-50%,-50%);width:200px}.login-container{max-width:420px;padding:1.5rem;position:relative;width:100%;z-index:1}.login-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:2.5rem 2rem}.login-header{margin-bottom:2rem;text-align:center}.login-logo-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:16px;box-shadow:0 8px 24px #3b82f64d;color:#fff;display:flex;height:64px;justify-content:center;margin:0 auto 1rem;width:64px}.login-title{color:#fff;font-size:1.75rem;font-weight:700;margin-bottom:.25rem}.login-subtitle{color:#ffffff80;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.login-error{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:10px;color:#fca5a5;display:flex;font-size:.85rem;gap:.5rem;padding:.75rem 1rem}.form-field label{color:#ffffffb3;display:block;font-size:.85rem;font-weight:500;margin-bottom:.35rem}.input-wrapper{position:relative}.input-icon{color:#ffffff4d;left:.85rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.input-wrapper input{background:#ffffff0f;border:1px solid #ffffff26;border-radius:10px;color:#fff;font-size:.9rem;outline:none;padding:.7rem .85rem .7rem 2.75rem;transition:all .2s ease;width:100%}.input-wrapper input::placeholder{color:#ffffff4d}.input-wrapper input:focus{background:#ffffff14;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.toggle-password{align-items:center;background:none;border:none;color:#ffffff4d;cursor:pointer;display:flex;padding:.25rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.toggle-password:hover{color:#fff9}.login-btn{border-radius:10px;font-size:1rem;margin-top:.5rem;padding:.75rem;position:relative}.login-btn:disabled{cursor:not-allowed;opacity:.6}.spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;display:inline-block;height:20px;width:20px}.login-footer{margin-top:2rem;text-align:center}.login-footer p{color:#ffffff4d;font-size:.75rem}@media (max-width:480px){.login-card{padding:2rem 1.25rem}}.mail-layout{display:flex;height:100vh;overflow:hidden}.sidebar{background:var(--sidebar-bg);color:var(--sidebar-text);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;transition:transform .3s ease;width:260px}.sidebar-logo{border-bottom:1px solid #ffffff1a;gap:.75rem;padding:1.25rem 1rem}.logo-icon,.sidebar-logo{align-items:center;display:flex}.logo-icon{background:linear-gradient(135deg,#3b82f6,#1e3a5f);border-radius:10px;color:#fff;flex-shrink:0;font-size:1.25rem;font-weight:700;height:38px;justify-content:center;width:38px}.logo-text{display:flex;flex-direction:column;line-height:1.2}.logo-title{color:#fff;font-size:1.1rem;font-weight:700}.logo-subtitle{color:#fff9;font-size:.75rem;font-weight:400}.sidebar-close{color:var(--sidebar-text);margin-left:auto}.sidebar-compose{padding:1rem}.sidebar-compose .btn{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;box-shadow:0 2px 8px #3b82f64d;font-size:.95rem;padding:.7rem 1rem;width:100%}.sidebar-compose .btn:hover{background:linear-gradient(135deg,#60a5fa,#3b82f6);box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.sidebar-nav{flex:1 1;overflow-y:auto;padding:0 .5rem}.nav-section{padding:.25rem 0}.nav-item{align-items:center;background:none;border:none;border-radius:8px;color:var(--sidebar-text);cursor:pointer;display:flex;font-size:.9rem;font-weight:400;gap:.75rem;padding:.6rem .75rem;text-align:left;text-decoration:none;transition:all .15s ease;width:100%}.nav-item:hover{background:var(--sidebar-hover);color:#fff;text-decoration:none}.nav-item.active{background:var(--sidebar-active);color:#fff;font-weight:500}.nav-label{flex:1 1}.nav-divider{background:#ffffff1a;height:1px;margin:.5rem .75rem}.sidebar-footer{border-top:1px solid #ffffff1a;gap:.75rem;padding:1rem}.sidebar-footer,.user-avatar{align-items:center;display:flex;flex-shrink:0}.user-avatar{background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;font-size:.9rem;font-weight:600;height:36px;justify-content:center;width:36px}.user-info{overflow:hidden}.user-name{color:#fff;font-size:.85rem;font-weight:500}.user-email,.user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:#ffffff80;font-size:.7rem}.main-content{background:var(--bg-secondary);display:flex;flex:1 1;flex-direction:column;overflow:hidden}.topbar{background:var(--bg-primary);border-bottom:1px solid var(--border-color);flex-shrink:0;height:56px;justify-content:space-between;padding:.5rem 1rem}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{flex:1 1;gap:.75rem}.search-bar{flex:1 1;max-width:400px;position:relative}.search-icon{color:var(--text-tertiary);left:.75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.85rem;outline:none;padding:.5rem .75rem .5rem 2.25rem;transition:all .2s ease;width:100%}.search-input:focus{border-color:var(--brand-accent);box-shadow:0 0 0 3px #3b82f61a}.topbar-right{align-items:center;display:flex;gap:.25rem}.lang-switcher{background:var(--bg-secondary);border-radius:6px;display:flex;gap:2px;margin-right:.5rem;padding:2px}.lang-btn{background:#0000;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;font-size:.7rem;font-weight:600;padding:.2rem .5rem;transition:all .15s ease}.lang-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.lang-btn.active{background:var(--brand-accent);color:#fff}.notification-btn{position:relative}.notification-dot{background:var(--brand-danger);border:2px solid var(--bg-primary);border-radius:50%;height:8px;position:absolute;right:4px;top:4px;width:8px}.page-content{flex:1 1;overflow-y:auto;padding:0}.hide-desktop,.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{bottom:0;left:0;position:fixed;top:0;transform:translateX(-100%);z-index:200}.sidebar.open{transform:translateX(0)}.hide-desktop{display:flex}.sidebar-overlay{background:#00000080;display:block;inset:0;position:fixed;z-index:150}.lang-switcher{display:none}}.inbox-page{display:flex;flex-direction:column;height:100%}.inbox-toolbar{align-items:center;background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem 1rem}.bulk-actions,.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:.25rem}.bulk-actions{border-left:1px solid var(--border-color);margin-left:.25rem;padding-left:.5rem}.selected-count{color:var(--text-secondary);font-size:.8rem;margin-left:.5rem}.pagination{align-items:center;display:flex;gap:.25rem}.page-info{color:var(--text-secondary);font-size:.8rem;margin-right:.25rem}.message-list{flex:1 1;overflow-y:auto}.message-row{align-items:center;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:.5rem;padding:.6rem 1rem;transition:background .1s ease}.message-row:hover{background:var(--bg-secondary)}.message-row.selected{background:#3b82f60f}.message-row.unread{background:var(--bg-primary)}.message-row.unread .msg-sender{color:var(--text-primary);font-weight:600}.message-row.unread .msg-subject{font-weight:600}.msg-checkbox{align-items:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;padding:.25rem}.message-row.selected .msg-checkbox,.msg-checkbox:hover{color:var(--brand-accent)}.msg-star{align-items:center;background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;flex-shrink:0;padding:.25rem}.msg-star.starred,.msg-star:hover{color:#f59e0b}.msg-content{cursor:pointer;flex:1 1;min-width:0}.msg-sender{color:var(--text-secondary);font-size:.85rem;max-width:200px}.msg-sender,.msg-subject-line{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.msg-subject-line{display:flex}.msg-subject{color:var(--text-primary);flex-shrink:0;font-size:.85rem}.msg-preview{color:var(--text-tertiary);font-size:.85rem;overflow:hidden;text-overflow:ellipsis}.msg-meta{align-items:center;display:flex;flex-shrink:0;gap:.5rem}.msg-attachment{color:var(--text-tertiary)}.msg-date{color:var(--text-secondary);font-size:.8rem;white-space:nowrap}.inbox-empty{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:.75rem;height:60%;justify-content:center}.inbox-empty h3{color:var(--text-secondary);font-weight:500}.inbox-empty p{font-size:.9rem}.spin{animation:spin 1s linear infinite}.btn-sm{font-size:.85rem;padding:.35rem .5rem}@media (max-width:768px){.msg-sender{max-width:120px}.msg-preview,.pagination .page-info{display:none}}.message-view{background:var(--bg-primary);display:flex;flex-direction:column;height:100%;overflow-y:auto}.message-view-loading{align-items:center;display:flex;height:100%;justify-content:center}.spinner-lg{animation:spin .7s linear infinite;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--brand-accent);height:36px;width:36px}.message-view-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;gap:1rem;height:60%;justify-content:center}.msg-action-bar{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem 1rem}.msg-actions-left,.msg-actions-right{align-items:center;display:flex;gap:.15rem}.msg-actions-right .starred{color:#f59e0b}.msg-header{border-bottom:1px solid var(--border-color);padding:1.5rem 1.5rem 1rem}.msg-title{color:var(--text-primary);font-size:1.35rem;font-weight:600;line-height:1.3;margin-bottom:1rem}.msg-participants{align-items:flex-start;display:flex;gap:.75rem}.msg-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.1rem;font-weight:600;height:42px;justify-content:center;width:42px}.msg-from-info{flex:1 1;min-width:0}.msg-from-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.msg-from-email{color:var(--text-tertiary);font-size:.8rem;font-weight:400}.msg-to-line{margin-top:.15rem}.msg-date-full,.msg-to-line{color:var(--text-secondary);font-size:.8rem}.msg-date-full{flex-shrink:0;white-space:nowrap}.msg-attachments{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:.75rem 1.5rem}.attachments-header{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.5rem;margin-bottom:.5rem}.attachment-list{display:flex;flex-wrap:wrap;gap:.5rem}.attachment-chip{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;display:flex;font-size:.8rem;gap:.35rem;padding:.35rem .75rem;transition:all .15s ease}.attachment-chip:hover{border-color:var(--brand-accent);color:var(--brand-accent)}.att-size{color:var(--text-tertiary);font-size:.75rem}.msg-body{flex:1 1;padding:1.5rem}.msg-html-content{word-wrap:break-word;color:var(--text-primary);font-size:.9rem;line-height:1.6;overflow-wrap:break-word}.msg-html-content a{color:var(--brand-accent)}.msg-html-content img{height:auto;max-width:100%}.msg-html-content blockquote{border-left:3px solid var(--border-color);color:var(--text-secondary);margin:.5rem 0;padding:.5rem 1rem}.msg-html-content pre{background:var(--bg-secondary);border-radius:6px;overflow-x:auto;padding:1rem}.msg-text-content{word-wrap:break-word;color:var(--text-primary);font-family:inherit;font-size:.9rem;line-height:1.6;white-space:pre-wrap}@media (max-width:768px){.msg-body,.msg-header{padding:1rem}.msg-participants{flex-direction:column}.msg-date-full{margin-top:.25rem}}@media print{.msg-action-bar{display:none}}

/*!
 * Quill Editor v1.3.7
 * https://quilljs.com/
 * Copyright (c) 2014, Jason Chen
 * Copyright (c) 2013, salesforce.com
 */.ql-container{box-sizing:border-box;font-family:Helvetica,Arial,sans-serif;font-size:13px;height:100%;margin:0;position:relative}.ql-container.ql-disabled .ql-tooltip{visibility:hidden}.ql-container.ql-disabled .ql-editor ul[data-checked]>li:before{pointer-events:none}.ql-clipboard{height:1px;left:-100000px;overflow-y:hidden;position:absolute;top:50%}.ql-clipboard p{margin:0;padding:0}.ql-editor{word-wrap:break-word;box-sizing:border-box;height:100%;line-height:1.42;outline:none;overflow-y:auto;padding:12px 15px;tab-size:4;-moz-tab-size:4;text-align:left;white-space:pre-wrap}.ql-editor>*{cursor:text}.ql-editor blockquote,.ql-editor h1,.ql-editor h2,.ql-editor h3,.ql-editor h4,.ql-editor h5,.ql-editor h6,.ql-editor ol,.ql-editor p,.ql-editor pre,.ql-editor ul{counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9;margin:0;padding:0}.ql-editor ol,.ql-editor ul{padding-left:1.5em}.ql-editor ol>li,.ql-editor ul>li{list-style-type:none}.ql-editor ul>li:before{content:"\2022"}.ql-editor ul[data-checked=false],.ql-editor ul[data-checked=true]{pointer-events:none}.ql-editor ul[data-checked=false]>li *,.ql-editor ul[data-checked=true]>li *{pointer-events:all}.ql-editor ul[data-checked=false]>li:before,.ql-editor ul[data-checked=true]>li:before{color:#777;cursor:pointer;pointer-events:all}.ql-editor ul[data-checked=true]>li:before{content:"\2611"}.ql-editor ul[data-checked=false]>li:before{content:"\2610"}.ql-editor li:before{display:inline-block;white-space:nowrap;width:1.2em}.ql-editor li:not(.ql-direction-rtl):before{margin-left:-1.5em;margin-right:.3em;text-align:right}.ql-editor li.ql-direction-rtl:before{margin-left:.3em;margin-right:-1.5em}.ql-editor ol li:not(.ql-direction-rtl),.ql-editor ul li:not(.ql-direction-rtl){padding-left:1.5em}.ql-editor ol li.ql-direction-rtl,.ql-editor ul li.ql-direction-rtl{padding-right:1.5em}.ql-editor ol li{counter-increment:list-0;counter-reset:list-1 list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li:before{content:counter(list-0,decimal) ". "}.ql-editor ol li.ql-indent-1{counter-increment:list-1}.ql-editor ol li.ql-indent-1:before{content:counter(list-1,lower-alpha) ". "}.ql-editor ol li.ql-indent-1{counter-reset:list-2 list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-2{counter-increment:list-2}.ql-editor ol li.ql-indent-2:before{content:counter(list-2,lower-roman) ". "}.ql-editor ol li.ql-indent-2{counter-reset:list-3 list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-3{counter-increment:list-3}.ql-editor ol li.ql-indent-3:before{content:counter(list-3,decimal) ". "}.ql-editor ol li.ql-indent-3{counter-reset:list-4 list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-4{counter-increment:list-4}.ql-editor ol li.ql-indent-4:before{content:counter(list-4,lower-alpha) ". "}.ql-editor ol li.ql-indent-4{counter-reset:list-5 list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-5{counter-increment:list-5}.ql-editor ol li.ql-indent-5:before{content:counter(list-5,lower-roman) ". "}.ql-editor ol li.ql-indent-5{counter-reset:list-6 list-7 list-8 list-9}.ql-editor ol li.ql-indent-6{counter-increment:list-6}.ql-editor ol li.ql-indent-6:before{content:counter(list-6,decimal) ". "}.ql-editor ol li.ql-indent-6{counter-reset:list-7 list-8 list-9}.ql-editor ol li.ql-indent-7{counter-increment:list-7}.ql-editor ol li.ql-indent-7:before{content:counter(list-7,lower-alpha) ". "}.ql-editor ol li.ql-indent-7{counter-reset:list-8 list-9}.ql-editor ol li.ql-indent-8{counter-increment:list-8}.ql-editor ol li.ql-indent-8:before{content:counter(list-8,lower-roman) ". "}.ql-editor ol li.ql-indent-8{counter-reset:list-9}.ql-editor ol li.ql-indent-9{counter-increment:list-9}.ql-editor ol li.ql-indent-9:before{content:counter(list-9,decimal) ". "}.ql-editor .ql-indent-1:not(.ql-direction-rtl){padding-left:3em}.ql-editor li.ql-indent-1:not(.ql-direction-rtl){padding-left:4.5em}.ql-editor .ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:3em}.ql-editor li.ql-indent-1.ql-direction-rtl.ql-align-right{padding-right:4.5em}.ql-editor .ql-indent-2:not(.ql-direction-rtl){padding-left:6em}.ql-editor li.ql-indent-2:not(.ql-direction-rtl){padding-left:7.5em}.ql-editor .ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:6em}.ql-editor li.ql-indent-2.ql-direction-rtl.ql-align-right{padding-right:7.5em}.ql-editor .ql-indent-3:not(.ql-direction-rtl){padding-left:9em}.ql-editor li.ql-indent-3:not(.ql-direction-rtl){padding-left:10.5em}.ql-editor .ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:9em}.ql-editor li.ql-indent-3.ql-direction-rtl.ql-align-right{padding-right:10.5em}.ql-editor .ql-indent-4:not(.ql-direction-rtl){padding-left:12em}.ql-editor li.ql-indent-4:not(.ql-direction-rtl){padding-left:13.5em}.ql-editor .ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:12em}.ql-editor li.ql-indent-4.ql-direction-rtl.ql-align-right{padding-right:13.5em}.ql-editor .ql-indent-5:not(.ql-direction-rtl){padding-left:15em}.ql-editor li.ql-indent-5:not(.ql-direction-rtl){padding-left:16.5em}.ql-editor .ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:15em}.ql-editor li.ql-indent-5.ql-direction-rtl.ql-align-right{padding-right:16.5em}.ql-editor .ql-indent-6:not(.ql-direction-rtl){padding-left:18em}.ql-editor li.ql-indent-6:not(.ql-direction-rtl){padding-left:19.5em}.ql-editor .ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:18em}.ql-editor li.ql-indent-6.ql-direction-rtl.ql-align-right{padding-right:19.5em}.ql-editor .ql-indent-7:not(.ql-direction-rtl){padding-left:21em}.ql-editor li.ql-indent-7:not(.ql-direction-rtl){padding-left:22.5em}.ql-editor .ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:21em}.ql-editor li.ql-indent-7.ql-direction-rtl.ql-align-right{padding-right:22.5em}.ql-editor .ql-indent-8:not(.ql-direction-rtl){padding-left:24em}.ql-editor li.ql-indent-8:not(.ql-direction-rtl){padding-left:25.5em}.ql-editor .ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:24em}.ql-editor li.ql-indent-8.ql-direction-rtl.ql-align-right{padding-right:25.5em}.ql-editor .ql-indent-9:not(.ql-direction-rtl){padding-left:27em}.ql-editor li.ql-indent-9:not(.ql-direction-rtl){padding-left:28.5em}.ql-editor .ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:27em}.ql-editor li.ql-indent-9.ql-direction-rtl.ql-align-right{padding-right:28.5em}.ql-editor .ql-video{display:block;max-width:100%}.ql-editor .ql-video.ql-align-center{margin:0 auto}.ql-editor .ql-video.ql-align-right{margin:0 0 0 auto}.ql-editor .ql-bg-black{background-color:#000}.ql-editor .ql-bg-red{background-color:#e60000}.ql-editor .ql-bg-orange{background-color:#f90}.ql-editor .ql-bg-yellow{background-color:#ff0}.ql-editor .ql-bg-green{background-color:#008a00}.ql-editor .ql-bg-blue{background-color:#06c}.ql-editor .ql-bg-purple{background-color:#93f}.ql-editor .ql-color-white{color:#fff}.ql-editor .ql-color-red{color:#e60000}.ql-editor .ql-color-orange{color:#f90}.ql-editor .ql-color-yellow{color:#ff0}.ql-editor .ql-color-green{color:#008a00}.ql-editor .ql-color-blue{color:#06c}.ql-editor .ql-color-purple{color:#93f}.ql-editor .ql-font-serif{font-family:Georgia,Times New Roman,serif}.ql-editor .ql-font-monospace{font-family:Monaco,Courier New,monospace}.ql-editor .ql-size-small{font-size:.75em}.ql-editor .ql-size-large{font-size:1.5em}.ql-editor .ql-size-huge{font-size:2.5em}.ql-editor .ql-direction-rtl{direction:rtl;text-align:inherit}.ql-editor .ql-align-center{text-align:center}.ql-editor .ql-align-justify{text-align:justify}.ql-editor .ql-align-right{text-align:right}.ql-editor.ql-blank:before{color:#0009;content:attr(data-placeholder);font-style:italic;left:15px;pointer-events:none;position:absolute;right:15px}.ql-snow .ql-toolbar:after,.ql-snow.ql-toolbar:after{clear:both;content:"";display:table}.ql-snow .ql-toolbar button,.ql-snow.ql-toolbar button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.ql-snow .ql-toolbar button svg,.ql-snow.ql-toolbar button svg{float:left;height:100%}.ql-snow .ql-toolbar button:active:hover,.ql-snow.ql-toolbar button:active:hover{outline:none}.ql-snow .ql-toolbar input.ql-image[type=file],.ql-snow.ql-toolbar input.ql-image[type=file]{display:none}.ql-snow .ql-toolbar .ql-picker-item.ql-selected,.ql-snow .ql-toolbar .ql-picker-item:hover,.ql-snow .ql-toolbar .ql-picker-label.ql-active,.ql-snow .ql-toolbar .ql-picker-label:hover,.ql-snow .ql-toolbar button.ql-active,.ql-snow .ql-toolbar button:focus,.ql-snow .ql-toolbar button:hover,.ql-snow.ql-toolbar .ql-picker-item.ql-selected,.ql-snow.ql-toolbar .ql-picker-item:hover,.ql-snow.ql-toolbar .ql-picker-label.ql-active,.ql-snow.ql-toolbar .ql-picker-label:hover,.ql-snow.ql-toolbar button.ql-active,.ql-snow.ql-toolbar button:focus,.ql-snow.ql-toolbar button:hover{color:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-fill,.ql-snow .ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:focus .ql-fill,.ql-snow .ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow .ql-toolbar button:hover .ql-fill,.ql-snow .ql-toolbar button:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-fill,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-fill,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-fill,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke.ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-fill,.ql-snow.ql-toolbar button.ql-active .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:focus .ql-fill,.ql-snow.ql-toolbar button:focus .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover .ql-fill,.ql-snow.ql-toolbar button:hover .ql-stroke.ql-fill{fill:#06c}.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow .ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow .ql-toolbar button.ql-active .ql-stroke,.ql-snow .ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow .ql-toolbar button:focus .ql-stroke,.ql-snow .ql-toolbar button:focus .ql-stroke-miter,.ql-snow .ql-toolbar button:hover .ql-stroke,.ql-snow .ql-toolbar button:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item.ql-selected .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-item:hover .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke,.ql-snow.ql-toolbar .ql-picker-label:hover .ql-stroke-miter,.ql-snow.ql-toolbar button.ql-active .ql-stroke,.ql-snow.ql-toolbar button.ql-active .ql-stroke-miter,.ql-snow.ql-toolbar button:focus .ql-stroke,.ql-snow.ql-toolbar button:focus .ql-stroke-miter,.ql-snow.ql-toolbar button:hover .ql-stroke,.ql-snow.ql-toolbar button:hover .ql-stroke-miter{stroke:#06c}@media (pointer:coarse){.ql-snow .ql-toolbar button:hover:not(.ql-active),.ql-snow.ql-toolbar button:hover:not(.ql-active){color:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-fill,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow .ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke,.ql-snow.ql-toolbar button:hover:not(.ql-active) .ql-stroke-miter{stroke:#444}}.ql-snow,.ql-snow *{box-sizing:border-box}.ql-snow .ql-hidden{display:none}.ql-snow .ql-out-bottom,.ql-snow .ql-out-top{visibility:hidden}.ql-snow .ql-tooltip{position:absolute;transform:translateY(10px)}.ql-snow .ql-tooltip a{cursor:pointer;text-decoration:none}.ql-snow .ql-tooltip.ql-flip{transform:translateY(-10px)}.ql-snow .ql-formats{display:inline-block;vertical-align:middle}.ql-snow .ql-formats:after{clear:both;content:"";display:table}.ql-snow .ql-stroke{fill:none;stroke:#444;stroke-linecap:round;stroke-linejoin:round;stroke-width:2}.ql-snow .ql-stroke-miter{fill:none;stroke:#444;stroke-miterlimit:10;stroke-width:2}.ql-snow .ql-fill,.ql-snow .ql-stroke.ql-fill{fill:#444}.ql-snow .ql-empty{fill:none}.ql-snow .ql-even{fill-rule:evenodd}.ql-snow .ql-stroke.ql-thin,.ql-snow .ql-thin{stroke-width:1}.ql-snow .ql-transparent{opacity:.4}.ql-snow .ql-direction svg:last-child{display:none}.ql-snow .ql-direction.ql-active svg:last-child{display:inline}.ql-snow .ql-direction.ql-active svg:first-child{display:none}.ql-snow .ql-editor h1{font-size:2em}.ql-snow .ql-editor h2{font-size:1.5em}.ql-snow .ql-editor h3{font-size:1.17em}.ql-snow .ql-editor h4{font-size:1em}.ql-snow .ql-editor h5{font-size:.83em}.ql-snow .ql-editor h6{font-size:.67em}.ql-snow .ql-editor a{text-decoration:underline}.ql-snow .ql-editor blockquote{border-left:4px solid #ccc;margin-bottom:5px;margin-top:5px;padding-left:16px}.ql-snow .ql-editor code,.ql-snow .ql-editor pre{background-color:#f0f0f0;border-radius:3px}.ql-snow .ql-editor pre{margin-bottom:5px;margin-top:5px;padding:5px 10px;white-space:pre-wrap}.ql-snow .ql-editor code{font-size:85%;padding:2px 4px}.ql-snow .ql-editor pre.ql-syntax{background-color:#23241f;color:#f8f8f2;overflow:visible}.ql-snow .ql-editor img{max-width:100%}.ql-snow .ql-picker{color:#444;display:inline-block;float:left;font-size:14px;font-weight:500;height:24px;position:relative;vertical-align:middle}.ql-snow .ql-picker-label{cursor:pointer;display:inline-block;height:100%;padding-left:8px;padding-right:2px;position:relative;width:100%}.ql-snow .ql-picker-label:before{display:inline-block;line-height:22px}.ql-snow .ql-picker-options{background-color:#fff;display:none;min-width:100%;padding:4px 8px;position:absolute;white-space:nowrap}.ql-snow .ql-picker-options .ql-picker-item{cursor:pointer;display:block;padding-bottom:5px;padding-top:5px}.ql-snow .ql-picker.ql-expanded .ql-picker-label{color:#ccc;z-index:2}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-fill{fill:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-label .ql-stroke{stroke:#ccc}.ql-snow .ql-picker.ql-expanded .ql-picker-options{display:block;margin-top:-1px;top:100%;z-index:1}.ql-snow .ql-color-picker,.ql-snow .ql-icon-picker{width:28px}.ql-snow .ql-color-picker .ql-picker-label,.ql-snow .ql-icon-picker .ql-picker-label{padding:2px 4px}.ql-snow .ql-color-picker .ql-picker-label svg,.ql-snow .ql-icon-picker .ql-picker-label svg{right:4px}.ql-snow .ql-icon-picker .ql-picker-options{padding:4px 0}.ql-snow .ql-icon-picker .ql-picker-item{height:24px;padding:2px 4px;width:24px}.ql-snow .ql-color-picker .ql-picker-options{padding:3px 5px;width:152px}.ql-snow .ql-color-picker .ql-picker-item{border:1px solid #0000;float:left;height:16px;margin:2px;padding:0;width:16px}.ql-snow .ql-picker:not(.ql-color-picker):not(.ql-icon-picker) svg{margin-top:-9px;position:absolute;right:0;top:50%;width:18px}.ql-snow .ql-picker.ql-font .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-item[data-label]:not([data-label=""]):before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-label]:not([data-label=""]):before{content:attr(data-label)}.ql-snow .ql-picker.ql-header{width:98px}.ql-snow .ql-picker.ql-header .ql-picker-item:before,.ql-snow .ql-picker.ql-header .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]:before{content:"Heading 1"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]:before{content:"Heading 2"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]:before{content:"Heading 3"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]:before{content:"Heading 4"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]:before{content:"Heading 5"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before,.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]:before{content:"Heading 6"}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]:before{font-size:2em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]:before{font-size:1.5em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]:before{font-size:1.17em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]:before{font-size:1em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]:before{font-size:.83em}.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]:before{font-size:.67em}.ql-snow .ql-picker.ql-font{width:108px}.ql-snow .ql-picker.ql-font .ql-picker-item:before,.ql-snow .ql-picker.ql-font .ql-picker-label:before{content:"Sans Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=serif]:before{content:"Serif"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before,.ql-snow .ql-picker.ql-font .ql-picker-label[data-value=monospace]:before{content:"Monospace"}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=serif]:before{font-family:Georgia,Times New Roman,serif}.ql-snow .ql-picker.ql-font .ql-picker-item[data-value=monospace]:before{font-family:Monaco,Courier New,monospace}.ql-snow .ql-picker.ql-size{width:98px}.ql-snow .ql-picker.ql-size .ql-picker-item:before,.ql-snow .ql-picker.ql-size .ql-picker-label:before{content:"Normal"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=small]:before{content:"Small"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=large]:before{content:"Large"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before,.ql-snow .ql-picker.ql-size .ql-picker-label[data-value=huge]:before{content:"Huge"}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=small]:before{font-size:10px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=large]:before{font-size:18px}.ql-snow .ql-picker.ql-size .ql-picker-item[data-value=huge]:before{font-size:32px}.ql-snow .ql-color-picker.ql-background .ql-picker-item{background-color:#fff}.ql-snow .ql-color-picker.ql-color .ql-picker-item{background-color:#000}.ql-toolbar.ql-snow{border:1px solid #ccc;box-sizing:border-box;font-family:Helvetica Neue,Helvetica,Arial,sans-serif;padding:8px}.ql-toolbar.ql-snow .ql-formats{margin-right:15px}.ql-toolbar.ql-snow .ql-picker-label{border:1px solid #0000}.ql-toolbar.ql-snow .ql-picker-options{border:1px solid #0000;box-shadow:0 2px 8px #0003}.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-label,.ql-toolbar.ql-snow .ql-picker.ql-expanded .ql-picker-options{border-color:#ccc}.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item.ql-selected,.ql-toolbar.ql-snow .ql-color-picker .ql-picker-item:hover{border-color:#000}.ql-toolbar.ql-snow+.ql-container.ql-snow{border-top:0}.ql-snow .ql-tooltip{background-color:#fff;border:1px solid #ccc;box-shadow:0 0 5px #ddd;color:#444;padding:5px 12px;white-space:nowrap}.ql-snow .ql-tooltip:before{content:"Visit URL:";line-height:26px;margin-right:8px}.ql-snow .ql-tooltip input[type=text]{border:1px solid #ccc;display:none;font-size:13px;height:26px;margin:0;padding:3px 5px;width:170px}.ql-snow .ql-tooltip a.ql-preview{display:inline-block;max-width:200px;overflow-x:hidden;text-overflow:ellipsis;vertical-align:top}.ql-snow .ql-tooltip a.ql-action:after{border-right:1px solid #ccc;content:"Edit";margin-left:16px;padding-right:8px}.ql-snow .ql-tooltip a.ql-remove:before{content:"Remove";margin-left:8px}.ql-snow .ql-tooltip a{line-height:26px}.ql-snow .ql-tooltip.ql-editing a.ql-preview,.ql-snow .ql-tooltip.ql-editing a.ql-remove{display:none}.ql-snow .ql-tooltip.ql-editing input[type=text]{display:inline-block}.ql-snow .ql-tooltip.ql-editing a.ql-action:after{border-right:0;content:"Save";padding-right:0}.ql-snow .ql-tooltip[data-mode=link]:before{content:"Enter link:"}.ql-snow .ql-tooltip[data-mode=formula]:before{content:"Enter formula:"}.ql-snow .ql-tooltip[data-mode=video]:before{content:"Enter video:"}.ql-snow a{color:#06c}.ql-container.ql-snow{border:1px solid #ccc}.compose-page{background:var(--bg-primary);display:flex;flex-direction:column;height:100%}.compose-page.minimized{height:auto}.compose-header{align-items:center;background:var(--sidebar-bg);border-radius:0;color:#fff;display:flex;flex-shrink:0;justify-content:space-between;padding:.75rem 1rem}.compose-header h3{font-size:.95rem;font-weight:500}.compose-header-actions{display:flex;gap:.25rem}.compose-header-actions .btn{color:#ffffffb3}.compose-header-actions .btn:hover{background:#ffffff1a;color:#fff}.compose-fields{flex-shrink:0;padding:0}.compose-error{background:#ef44441a;border-bottom:1px solid #ef444433;color:var(--brand-danger);font-size:.85rem;padding:.5rem 1rem}.compose-field{align-items:center;border-bottom:1px solid var(--border-color);display:flex;padding:.35rem 1rem}.compose-field label{color:var(--text-secondary);flex-shrink:0;font-size:.85rem;font-weight:500;width:60px}.compose-field input{background:#0000;border:none;color:var(--text-primary);flex:1 1;font-size:.9rem;outline:none;padding:.4rem 0}.field-row{align-items:center;display:flex;flex:1 1}.field-row input{flex:1 1}.cc-toggles{display:flex;flex-shrink:0;gap:.25rem}.cc-toggles button{background:none;border:none;border-radius:4px;color:var(--text-tertiary);cursor:pointer;font-size:.8rem;padding:.25rem .5rem}.cc-toggles button:hover{background:var(--bg-secondary);color:var(--brand-accent)}.compose-editor{min-height:0}.compose-editor,.compose-editor .quill{display:flex;flex:1 1;flex-direction:column}.compose-editor .ql-container{border:none;border-top:1px solid var(--border-color);flex:1 1;font-family:var(--font-primary);font-size:.9rem}.compose-editor .ql-toolbar{background:var(--bg-secondary);border:none;border-bottom:1px solid var(--border-color)}.compose-editor .ql-editor{color:var(--text-primary);min-height:200px;padding:1rem 1.25rem}.compose-editor .ql-editor.ql-blank:before{color:var(--text-tertiary);font-style:normal}.compose-attachments{border-top:1px solid var(--border-color);display:flex;flex-shrink:0;flex-wrap:wrap;gap:.5rem;padding:.5rem 1rem}.attachment-item{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);display:flex;font-size:.8rem;gap:.35rem;padding:.3rem .6rem}.att-filename{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-filesize{color:var(--text-tertiary);font-size:.75rem}.attachment-item button{background:none;border:none;color:var(--text-tertiary);cursor:pointer;display:flex;padding:.15rem}.attachment-item button:hover{color:var(--brand-danger)}.compose-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:.5rem 1rem}.compose-footer-left,.compose-footer-right{align-items:center;display:flex;gap:.25rem}.compose-footer-left .btn-primary{align-items:center;display:flex;gap:.5rem;padding:.45rem 1.25rem}@media (max-width:768px){.compose-field label{font-size:.8rem;width:40px}}.contacts-page{height:100%;overflow-y:auto;padding:1.5rem}.contacts-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.contacts-header h2{color:var(--text-primary);font-size:1.25rem;font-weight:600}.contacts-header .btn-primary{align-items:center;display:flex;gap:.5rem}.contacts-search{margin-bottom:1.5rem;max-width:400px;position:relative}.contacts-search .search-icon{color:var(--text-tertiary);left:.75rem;position:absolute;top:50%;transform:translateY(-50%)}.contacts-search input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.9rem;outline:none;padding:.6rem .75rem .6rem 2.25rem;width:100%}.contacts-search input:focus{border-color:var(--brand-accent);box-shadow:0 0 0 3px #3b82f61a}.contacts-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.contact-card{align-items:flex-start;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;display:flex;gap:.75rem;padding:1rem;transition:all .15s ease}.contact-card:hover{border-color:var(--brand-accent);box-shadow:0 2px 8px #0000000d}.contact-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.95rem;font-weight:600;height:44px;justify-content:center;width:44px}.contact-info{flex:1 1;min-width:0}.contact-name{color:var(--text-primary);font-size:.95rem;font-weight:500;margin-bottom:.25rem}.contact-detail{align-items:center;color:var(--text-secondary);display:flex;font-size:.8rem;gap:.35rem;margin-top:.15rem}.contact-detail span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-actions{display:flex;flex-shrink:0;gap:.15rem;opacity:0;transition:opacity .15s ease}.contact-card:hover .contact-actions{opacity:1}.contacts-empty,.contacts-loading{align-items:center;color:var(--text-tertiary);display:flex;flex-direction:column;gap:.75rem;grid-column:1/-1;justify-content:center;padding:3rem}.contacts-empty h3{color:var(--text-secondary);font-weight:500}.modal-overlay{padding:1rem}.modal-content{background:var(--bg-primary);border-radius:12px;box-shadow:0 20px 60px #0003;max-width:460px;overflow:hidden;width:100%}.modal-header{padding:1rem 1.25rem}.modal-header h3{font-size:1rem;font-weight:600}.modal-body{display:flex;flex-direction:column;gap:1rem;padding:1.25rem}.form-group label{color:var(--text-secondary);display:block;font-size:.85rem;font-weight:500;margin-bottom:.3rem}.form-group input,.form-group textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.9rem;outline:none;padding:.55rem .75rem;resize:vertical;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--brand-accent);box-shadow:0 0 0 3px #3b82f61a}.modal-footer{gap:.5rem;padding:1rem 1.25rem}.modal-footer .btn-primary{align-items:center;display:flex;gap:.5rem}@media (max-width:768px){.contacts-grid{grid-template-columns:1fr}.contact-actions{opacity:1}}.settings-page{display:flex;height:100%;overflow:hidden}.settings-sidebar{background:var(--bg-primary);border-right:1px solid var(--border-color);flex-shrink:0;overflow-y:auto;padding:1.5rem 1rem;width:220px}.settings-title{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:1rem;padding:0 .5rem}.settings-nav{display:flex;flex-direction:column;gap:.15rem}.settings-tab{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.9rem;gap:.65rem;padding:.6rem .75rem;text-align:left;transition:all .15s ease;width:100%}.settings-tab:hover{background:var(--bg-secondary);color:var(--text-primary)}.settings-tab.active{background:var(--bg-secondary);color:var(--brand-accent);font-weight:500}.settings-content{flex:1 1;overflow-y:auto;padding:2rem}.settings-section h3{color:var(--text-primary);font-size:1.15rem;font-weight:600;margin-bottom:.25rem}.section-desc{color:var(--text-secondary);font-size:.85rem;margin-bottom:1.5rem}.settings-error{background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:var(--brand-danger);font-size:.85rem;margin-bottom:1rem;padding:.6rem 1rem}.settings-avatar-section{align-items:center;display:flex;gap:1rem;margin-bottom:1.5rem}.settings-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:50%;color:#fff;display:flex;font-size:1.3rem;font-weight:600;height:56px;justify-content:center;width:56px}.avatar-email{color:var(--text-primary);font-size:.9rem;font-weight:500}.avatar-role{color:var(--text-tertiary);font-size:.8rem;text-transform:capitalize}.settings-section .form-group{margin-bottom:1rem;max-width:400px}.settings-section .btn-primary{align-items:center;display:flex;gap:.5rem;margin-top:.5rem}.password-input{position:relative}.password-input input{padding-right:2.5rem;width:100%}.toggle-pw{background:none;border:none;color:var(--text-tertiary);cursor:pointer;position:absolute;right:.75rem;top:50%;transform:translateY(-50%)}.theme-options{display:flex;gap:1rem}.theme-card{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;padding:1rem;text-align:center;transition:all .15s ease;width:160px}.theme-card.active,.theme-card:hover{border-color:var(--brand-accent)}.theme-card.active{box-shadow:0 0 0 3px #3b82f61a}.theme-preview{border:1px solid var(--border-color);border-radius:6px;display:flex;height:80px;margin-bottom:.5rem;overflow:hidden}.light-preview{background:#f8f9fa}.light-preview .tp-sidebar{background:#1e3a5f;width:25%}.light-preview .tp-content{flex:1 1;padding:6px}.light-preview .tp-bar{height:8px;margin-bottom:4px}.light-preview .tp-bar,.light-preview .tp-lines div{background:#fff;border:1px solid #e5e7eb;border-radius:2px}.light-preview .tp-lines div{height:6px;margin-bottom:3px}.dark-preview{background:#1e1e2e}.dark-preview .tp-sidebar{background:#0f172a;width:25%}.dark-preview .tp-content{flex:1 1;padding:6px}.dark-preview .tp-bar{background:#2a2a3e;border-radius:2px;height:8px;margin-bottom:4px}.dark-preview .tp-lines div{background:#2a2a3e;border-radius:2px;height:6px;margin-bottom:3px}.theme-card span{color:var(--text-primary);font-size:.85rem;font-weight:500}.toggle-list{display:flex;flex-direction:column;gap:1rem}.toggle-item{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;display:flex;justify-content:space-between;max-width:500px;padding:1rem}.toggle-item h4{color:var(--text-primary);font-size:.9rem;font-weight:500;margin-bottom:.15rem}.toggle-item p{color:var(--text-tertiary);font-size:.8rem}.switch{flex-shrink:0;height:24px;position:relative;width:44px}.switch input{height:0;opacity:0;width:0}.slider{background:var(--border-color);border-radius:24px;cursor:pointer;inset:0}.slider,.slider:before{position:absolute;transition:.2s}.slider:before{background:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;width:18px}.switch input:checked+.slider{background:var(--brand-accent)}.switch input:checked+.slider:before{transform:translateX(20px)}.language-list{display:flex;flex-direction:column;gap:.5rem;max-width:350px}.language-option{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:10px;cursor:pointer;display:flex;gap:.75rem;padding:.75rem 1rem;text-align:left;transition:all .15s ease;width:100%}.language-option.active,.language-option:hover{border-color:var(--brand-accent)}.language-option.active{background:#3b82f60d}.lang-flag{font-size:1.3rem}.lang-name{color:var(--text-primary);flex:1 1;font-size:.9rem;font-weight:500}.lang-check{color:var(--brand-accent)}@media (max-width:768px){.settings-page{flex-direction:column}.settings-sidebar{border-bottom:1px solid var(--border-color);border-right:none;padding:1rem;width:100%}.settings-nav{flex-direction:row;gap:.5rem;overflow-x:auto}.settings-tab span{display:none}.settings-content{padding:1rem}.theme-options{flex-direction:column}.theme-card{width:100%}}.admin-page{height:100%;overflow-y:auto;padding:1.5rem}.admin-loading{align-items:center;display:flex;height:100%;justify-content:center}.admin-header{margin-bottom:1.5rem}.admin-header h2{color:var(--text-primary);font-size:1.25rem;font-weight:600}.admin-header-desc{color:var(--text-secondary);font-size:.85rem;margin-top:.25rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:1.5rem}.stat-card{align-items:center;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;display:flex;gap:1rem;padding:1.25rem;transition:all .15s ease}.stat-card:hover{box-shadow:0 4px 12px #0000000d}.stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-info{display:flex;flex-direction:column}.stat-value{color:var(--text-primary);font-size:1.5rem;font-weight:700;line-height:1.2}.stat-label{color:var(--text-secondary);font-size:.8rem}.admin-panels{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.admin-panel{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.panel-title{align-items:center;border-bottom:1px solid var(--border-color);color:var(--text-primary);display:flex;font-size:.95rem;font-weight:600;gap:.5rem}.panel-content,.panel-title{padding:1rem 1.25rem}.panel-empty{color:var(--text-tertiary);font-size:.85rem;padding:1rem;text-align:center}.activity-list{display:flex;flex-direction:column;gap:.75rem}.activity-item{align-items:center;display:flex;gap:.75rem}.activity-dot{background:var(--brand-accent);border-radius:50%;flex-shrink:0;height:8px;width:8px}.activity-info{display:flex;flex:1 1;flex-direction:column}.activity-action{color:var(--text-primary);font-size:.85rem}.activity-time,.activity-user{color:var(--text-tertiary);font-size:.75rem}.activity-time{white-space:nowrap}.status-list{display:flex;flex-direction:column;gap:.5rem}.status-item{align-items:center;color:var(--text-primary);display:flex;font-size:.85rem;gap:.5rem}.status-item span:nth-child(2){flex:1 1}.status-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.status-dot.online{background:#10b981}.status-dot.offline{background:#ef4444}.status-tag{border-radius:4px;font-size:.7rem;font-weight:600;padding:.15rem .5rem;text-transform:uppercase}.status-tag.online{background:#10b9811a;color:#10b981}.status-tag.offline{background:#ef44441a;color:#ef4444}.admin-table-container{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.admin-table-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.25rem}.admin-table-header h3{font-size:.95rem;font-weight:600}.admin-table-actions{align-items:center;display:flex;gap:.5rem}.admin-search{position:relative}.admin-search input{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);font-size:.85rem;outline:none;padding:.4rem .6rem .4rem 2rem;width:220px}.admin-search input:focus{border-color:var(--brand-accent)}.admin-search .search-icon{color:var(--text-tertiary);left:.6rem;position:absolute;top:50%;transform:translateY(-50%)}table.admin-table{border-collapse:collapse;width:100%}.admin-table th{background:var(--bg-secondary);color:var(--text-tertiary);font-size:.75rem;font-weight:600;letter-spacing:.03em;padding:.6rem 1.25rem;text-align:left;text-transform:uppercase}.admin-table td,.admin-table th{border-bottom:1px solid var(--border-color)}.admin-table td{color:var(--text-primary);font-size:.85rem;padding:.65rem 1.25rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-secondary)}.admin-table .cell-actions{display:flex;gap:.25rem}.admin-table-footer{align-items:center;border-top:1px solid var(--border-color);color:var(--text-secondary);display:flex;font-size:.8rem;justify-content:space-between;padding:.75rem 1.25rem}.table-pagination{align-items:center;display:flex;gap:.25rem}.role-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.15rem .5rem}.role-badge.admin{background:#8b5cf61a;color:#8b5cf6}.role-badge.user{background:#3b82f61a;color:#3b82f6}.status-badge{border-radius:4px;font-size:.75rem;font-weight:500;padding:.15rem .5rem}.status-badge.active{background:#10b9811a;color:#10b981}.status-badge.inactive{background:#ef44441a;color:#ef4444}@media (max-width:768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.admin-panels{grid-template-columns:1fr}.admin-table-container{overflow-x:auto}}:root{--brand-primary:#1e3a5f;--brand-primary-light:#2a5087;--brand-primary-dark:#142844;--brand-accent:#3b82f6;--brand-accent-light:#60a5fa;--brand-success:#10b981;--brand-warning:#f59e0b;--brand-danger:#ef4444;--bg-primary:#fff;--bg-secondary:#f3f4f6;--bg-tertiary:#e5e7eb;--bg-hover:#f9fafb;--bg-active:#eff6ff;--text-primary:#111827;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--border-color:#e5e7eb;--border-light:#f3f4f6;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--sidebar-bg:#1e3a5f;--sidebar-text:#e2e8f0;--sidebar-hover:#ffffff1a;--sidebar-active:#fff3;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--transition:all 0.2s ease}[data-theme=dark]{--bg-primary:#111827;--bg-secondary:#1f2937;--bg-tertiary:#374151;--bg-hover:#1f2937;--bg-active:#1e3a5f33;--text-primary:#f9fafb;--text-secondary:#9ca3af;--text-tertiary:#6b7280;--border-color:#374151;--border-light:#1f2937;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0006;--shadow-lg:0 10px 15px -3px #0006;--sidebar-bg:#0f172a;--sidebar-text:#e2e8f0}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background-color:#fff;background-color:var(--bg-primary);color:#111827;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-family);line-height:1.6;overflow:hidden}a{color:#3b82f6;color:var(--brand-accent);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer}button,input,select,textarea{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-family)}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#9ca3af;background:var(--text-tertiary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#6b7280;background:var(--text-secondary)}.loading-screen{align-items:center;background:#fff;background:var(--bg-primary);display:flex;height:100vh;justify-content:center}.spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-top-color:#3b82f6;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--brand-accent);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-full{width:100%}.h-full{height:100%}.text-sm{font-size:.875rem;font-size:var(--font-size-sm)}.text-xs{font-size:.75rem;font-size:var(--font-size-xs)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.text-secondary{color:#6b7280;color:var(--text-secondary)}.truncate{overflow:hidden;text-overflow:ellipsis}.btn,.truncate{white-space:nowrap}.btn{align-items:center;border:1px solid #0000;border-radius:.5rem;border-radius:var(--radius-md);display:inline-flex;font-size:.875rem;font-size:var(--font-size-sm);font-weight:500;gap:.5rem;justify-content:center;padding:.5rem 1rem;transition:all .2s ease;transition:var(--transition)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#3b82f6;background:var(--brand-accent);border-color:#3b82f6;border-color:var(--brand-accent);color:#fff}.btn-primary:hover:not(:disabled){background:#60a5fa;background:var(--brand-accent-light)}.btn-secondary{background:#f3f4f6;background:var(--bg-secondary);border-color:#e5e7eb;border-color:var(--border-color);color:#111827;color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:#e5e7eb;background:var(--bg-tertiary)}.btn-danger{background:#ef4444;background:var(--brand-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-ghost{background:#0000;border:none;border-radius:.375rem;border-radius:var(--radius-sm);color:#6b7280;color:var(--text-secondary);padding:.375rem}.btn-ghost:hover{background:#f9fafb;background:var(--bg-hover);color:#111827;color:var(--text-primary)}.btn-sm{font-size:.75rem;font-size:var(--font-size-xs);padding:.25rem .75rem}.btn-lg{font-size:1rem;font-size:var(--font-size-base);padding:.75rem 1.5rem}.input{background:#fff;background:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:.5rem;border-radius:var(--radius-md);color:#111827;color:var(--text-primary);font-size:.875rem;font-size:var(--font-size-sm);outline:none;padding:.5rem .75rem;transition:all .2s ease;transition:var(--transition);width:100%}.input:focus{border-color:#3b82f6;border-color:var(--brand-accent);box-shadow:0 0 0 3px #3b82f61a}.input::placeholder{color:#9ca3af;color:var(--text-tertiary)}.card{background:#fff;background:var(--bg-primary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);padding:1.5rem}.badge{align-items:center;background:#3b82f6;background:var(--brand-accent);border-radius:9999px;color:#fff;display:inline-flex;font-size:.75rem;font-size:var(--font-size-xs);font-weight:500;padding:.125rem .5rem}.badge-success{background:#10b981;background:var(--brand-success)}.badge-warning{background:#f59e0b;background:var(--brand-warning);color:#111827}.badge-danger{background:#ef4444;background:var(--brand-danger)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}td,th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);font-size:.875rem;font-size:var(--font-size-sm);padding:.75rem 1rem;text-align:left}th{background:#f3f4f6;background:var(--bg-secondary);color:#6b7280;color:var(--text-secondary);font-weight:600}tr:hover{background:#f9fafb;background:var(--bg-hover)}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{animation:slideUp .3s ease;background:#fff;background:var(--bg-primary);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:1rem 1.5rem}.modal-body{padding:1.5rem}.modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--border-color);display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.hide-mobile{display:none!important}.sidebar{position:fixed;transform:translateX(-100%);transition:transform .3s ease;z-index:100}.sidebar.open{transform:translateX(0)}}
/*# sourceMappingURL=main.83fa536a.css.map*/