.footer{background-color:#f6f8fa;border-top:1px solid #d0d7de;padding:24px 0;margin-top:auto;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.footer-content{max-width:1200px;margin:0 auto;padding:0 16px;display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:16px}.footer-link{color:#656d76;text-decoration:none;font-size:12px;font-weight:400;transition:color .2s ease-in-out}.footer-link:hover{color:#0969da;text-decoration:underline}@media (max-width: 768px){.footer-content{flex-direction:column;gap:12px}.footer-link{font-size:11px}}@media (max-width: 480px){.footer{padding:16px 0}.footer-content{padding:0 12px;gap:8px}}.logo{display:flex;align-items:center;gap:8px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.logo-icon{display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--logo-bg-color, var(--primary));flex-shrink:0}.logo-icon-svg{width:80%;height:80%;color:var(--logo-color, white)}.logo-text{font-weight:600;color:var(--text-primary);white-space:nowrap}.logo.small .logo-icon{width:24px;height:24px}.logo.small .logo-text{font-size:16px}.logo.medium .logo-icon{width:36px;height:36px}.logo.medium .logo-text{font-size:18px}.logo.large .logo-icon{width:48px;height:48px}.logo.large .logo-text{font-size:20px}.logo.xl .logo-icon{width:80px;height:80px}.logo.xl .logo-text{font-size:36px}@media (max-width: 768px){.logo.large .logo-icon{width:40px;height:40px}.logo.large .logo-text{font-size:18px}.logo.xl .logo-icon{width:60px;height:60px}.logo.xl .logo-text{font-size:24px}}@media (max-width: 480px){.logo.large .logo-icon{width:40px;height:40px}.logo.large .logo-text{font-size:16px}.logo.xl .logo-icon{width:52px;height:52px}.logo.xl .logo-text{font-size:20px}}.logo.primary{--logo-bg-color: var(--primary);--logo-color: white}.logo.white{--logo-bg-color: white;--logo-color: var(--primary)}.logo.transparent{--logo-bg-color: transparent;--logo-color: var(--primary)}.logo.dark{--logo-bg-color: var(--oc-gray-8);--logo-color: white}.auth-page{min-height:100vh;display:flex;flex-direction:column}.auth-container{flex:1;background:#fff;display:flex;flex-direction:row;align-items:center;justify-content:center;padding:40px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;gap:80px}.auth-branding{flex:1;max-width:580px;padding-right:40px}.auth-form-container{flex:0 0 400px;display:flex;flex-direction:column;align-items:center;justify-content:center}.auth-logo{margin-bottom:16px;justify-content:flex-start}.auth-logo .logo-icon-svg,.auth-logo .logo-text{color:var(--primary)}.auth-tagline{font-size:32px;font-weight:400;color:var(--text-secondary);line-height:1.34;margin:0;text-align:left;max-width:100%}.auth-card{width:100%;max-width:400px;text-align:center;background:#fff;border:1px solid var(--border);border-radius:8px;padding:24px;box-shadow:0 2px 8px #00000014}.auth-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 20px;line-height:1}.auth-logo-xl .logo-icon{width:80px;height:80px}.auth-logo-xl .logo-text{font-size:32px}.auth-form{margin-bottom:12px}.form-group{margin-bottom:16px;text-align:left}.form-group:last-child{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.form-input{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-weight:400;background:#fff;box-sizing:border-box;line-height:1.4;min-height:36px}.form-input:hover{border-color:var(--primary)}.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #228be61a}.form-input:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.form-input::placeholder{color:var(--text-subtle)}.form-input.error{border-color:var(--error)}.form-input.error:focus{border-color:var(--error);box-shadow:0 0 0 3px #fa52521a}.form-input-with-icon{padding-right:44px}.form-input-with-match-icons{padding-right:80px}.input-container{position:relative}.input-icon-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;fill:var(--text-muted);cursor:pointer;padding:2px;border-radius:4px;transition:background-color .2s ease}.input-icon-right:hover{fill:var(--primary);background-color:#228be61a}.auth-button{width:100%;padding:8px 16px;border:1px solid transparent;border-radius:6px;font-size:14px;font-weight:500;color:#fff;background:var(--success-text);cursor:pointer;line-height:1.4;min-height:36px;transition:background-color .2s ease}.auth-button:hover:not(:disabled){background:var(--success-text)}.auth-button:active:not(:disabled){transform:translateY(1px)}.auth-button:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.google-button{width:100%;padding:8px 16px;border:1px solid var(--border);border-radius:6px;font-size:14px;font-weight:500;color:var(--text-primary);background:#fff;cursor:pointer;line-height:1.4;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s ease;margin-bottom:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:36px}.google-button:hover{background:var(--surface-hover);border-color:var(--border-hover)}.google-button:active{transform:translateY(1px)}.google-button:disabled{background:var(--border);color:var(--text-muted);cursor:not-allowed}.google-icon{width:18px;height:18px;flex-shrink:0}.form-error{color:var(--error);font-size:12px;margin-top:4px;display:block}.password-match-icons{display:flex;align-items:center;gap:8px}.match-icon{width:16px;height:16px}.match-icon.success{fill:var(--success)}.match-icon.error{fill:var(--error)}.alert{padding:16px;border-radius:6px;margin-bottom:16px;border:1px solid var(--error-border);background-color:var(--error-light);color:var(--error-text);font-size:14px;text-align:left}.auth-divider{text-align:center;margin:8px 0 12px;position:relative;color:var(--text-muted);font-size:12px}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-subtle);z-index:1}.auth-divider span{background:#fff;padding:0 16px;position:relative;z-index:2}.auth-links{text-align:center}.auth-link{color:var(--primary);text-decoration:none;font-weight:500;font-size:14px;transition:all .2s ease-in-out;padding:4px;border-radius:4px;display:inline-block}.auth-link:hover{color:var(--primary-hover);text-decoration:underline;background-color:#228be61a}.auth-text{color:var(--text-muted);margin:0 0 8px;font-size:14px}@media (max-width: 1024px){.auth-container{flex-direction:column;gap:24px;padding:20px;min-height:auto}.auth-branding{padding-right:0;max-width:100%;text-align:center;flex:none}.auth-logo{justify-content:center;margin-bottom:12px}.auth-tagline{font-size:22px;text-align:center;margin-bottom:0;max-width:400px;margin-left:auto;margin-right:auto}.auth-form-container{flex:none;width:100%;max-width:400px;margin:0 auto}.auth-card{max-width:400px;width:100%;padding:24px;margin:0}.auth-title{font-size:20px;margin-bottom:16px}.auth-logo-xl .logo-icon{width:68px;height:68px}.auth-logo-xl .logo-text{font-size:26px}.form-input{padding:10px 14px;font-size:16px;min-height:44px}.auth-button,.google-button{padding:10px 16px;font-size:16px;min-height:44px}.input-icon-right{width:20px;height:20px;right:14px;padding:4px}.form-input-with-icon{padding-right:52px}}@media (max-width: 480px){.auth-container{padding:16px;gap:20px}.auth-card{max-width:100%;width:calc(100% - 32px);padding:20px;border-radius:6px;margin:0}.auth-tagline{font-size:18px;padding:0 10px}.auth-title{font-size:18px;margin-bottom:12px}.auth-logo-xl .logo-icon{width:56px;height:56px}.auth-logo-xl .logo-text{font-size:22px}.auth-logo{margin-bottom:8px}.form-group{margin-bottom:12px}.form-group:last-child{margin-bottom:16px}.auth-divider{margin:12px 0 16px}.auth-links{margin-top:8px}.auth-text{margin:0 0 6px;font-size:13px}.auth-link{font-size:13px}.form-input,.auth-button,.google-button{padding:12px 16px;font-size:16px;min-height:44px}.input-icon-right{width:20px;height:20px;right:16px;padding:4px}.form-input-with-icon{padding-right:56px}}@media (max-width: 360px){.auth-container{padding:4px}.auth-card{max-width:100%;padding:12px;margin:0 8px}.auth-title{font-size:16px}.form-input,.auth-button,.google-button{padding:10px 12px;min-height:40px}.input-icon-right{width:18px;height:18px;right:12px}.form-input-with-icon{padding-right:48px}}@media screen and (-webkit-min-device-pixel-ratio: 0){.form-input{font-size:16px}}.app-layout{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-content{flex:1;display:flex;flex-direction:row;min-height:0;position:relative}@media (max-width: 768px){.app-content,.app-content.sidebar-open{overflow:hidden}}@media (max-width: 480px){.app-layout{height:100vh;height:100dvh}}.form-container{margin-top:8px;text-align:left}.form-field{margin-bottom:16px;position:relative;text-align:left}.form-field-input-container{position:relative;display:flex;align-items:center}.form-field-input{width:100%;padding:12px 16px 12px 48px;border:1px solid var(--border);border-radius:6px;font-size:16px;font-weight:400;background:#fff;box-sizing:border-box;transition:border-color .2s ease}.form-field-input:hover{border-color:var(--primary)}.form-field-input:focus{outline:none;border-color:var(--primary);border-width:2px;padding-left:47px}.form-field-input.error{border-color:var(--error)}.form-field-input.error:focus{border-color:var(--error)}.form-field-input::placeholder{color:var(--text-subtle)}.form-field-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;fill:var(--text-muted);pointer-events:none;z-index:1}.form-field-error{color:var(--error);font-size:14px;margin-top:6px;display:block;text-align:left}.form-field-label{display:block;font-size:14px;color:var(--text-secondary);margin-bottom:8px;text-align:left}.form-field-file-row{display:flex;align-items:center;gap:12px}.avatar-preview{width:44px;height:44px;border-radius:999px;background:var(--surface);border:1px solid var(--border);display:inline-flex;align-items:center;justify-content:center;color:var(--text-subtle);overflow:hidden}.avatar-preview img{width:100%;height:100%;object-fit:cover}.file-button{background:var(--primary-subtle);color:var(--primary-active);padding:8px 12px;border-radius:6px;cursor:pointer;border:1px solid var(--primary-light);font-weight:500}.file-input{display:none}.file-name{max-width:220px;color:var(--text-secondary);font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.form-hint{margin-top:6px;font-size:12px;color:var(--text-subtle)}@media (max-width: 768px){.form-container{margin-top:8px}.form-field{margin-bottom:14px}.form-field-input{padding:10px 14px 10px 42px;font-size:16px;border-radius:6px}.form-field-input:focus{padding-left:41px}.form-field-icon{left:14px;width:18px;height:18px}.form-field-error{font-size:13px;margin-top:4px}.form-field-label{font-size:14px;margin-bottom:6px}.form-field-file-row{gap:10px}.avatar-preview{width:36px;height:36px}.file-button{padding:8px 12px;border-radius:6px;font-size:14px}.file-name{max-width:180px;font-size:13px}}@media (max-width: 480px){.form-field{margin-bottom:12px}.form-field-input{padding:9px 12px 9px 38px;border-radius:5px}.form-field-input:focus{padding-left:37px}.form-field-icon{left:12px;width:16px;height:16px}.avatar-preview{width:32px;height:32px}.file-button{padding:7px 10px;font-size:13px}.file-name{max-width:150px;font-size:12px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal-content{background:#fff;border-radius:12px;border:1px solid var(--border);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0000001f}.modal-header{padding:24px 24px 0;display:flex;align-items:center;justify-content:space-between;border-bottom:none}.modal-title{font-size:20px;font-weight:600;margin:0;color:var(--text-primary)}.modal-close-button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.modal-close-button:hover{background:var(--surface-hover);color:var(--text-primary)}.modal-close-button ion-icon{font-size:24px;width:24px;height:24px}.modal-body{padding:24px;background:#fff}.modal-alert{padding:12px 16px;border-radius:6px;margin-bottom:20px;border:1px solid var(--error-border);background-color:var(--error-light);color:var(--error-text);font-size:14px;display:flex;align-items:center;justify-content:space-between}.modal-alert-close{background:none;border:none;color:var(--error-hover);cursor:pointer;padding:4px;font-size:18px;line-height:1}.modal-actions{padding:0 24px 24px;background:#fff;display:flex;gap:12px;justify-content:flex-end}.modal-button{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}.modal-button-cancel{background:#fff;color:var(--text-secondary);border:1px solid var(--border-subtle)}.modal-button-cancel:hover{background:var(--surface-hover);border-color:var(--border)}.modal-button-submit{background:var(--primary);color:#fff}.modal-button-submit:hover:not(:disabled){background:var(--primary-hover)}.modal-button-submit:disabled{background:var(--border-subtle);color:var(--text-muted);cursor:not-allowed}.success-notification{position:fixed;top:20px;right:20px;background:var(--success-light);color:var(--success-text);border:1px solid var(--success-border);border-radius:6px;padding:16px;box-shadow:0 4px 12px #0000001a;z-index:1001}@media (max-width: 768px){.modal-overlay{padding:8px}.modal-content{max-height:95vh}.modal-header{padding:20px 20px 0}.modal-body{padding:20px}.modal-actions{padding:0 20px 20px;flex-direction:column}.modal-button{width:100%;justify-content:center}}.action-button{background-color:var(--primary-light);color:#fff;padding:12px 24px;border:none;border-radius:16px;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;transition:background-color .2s ease;min-height:44px;box-sizing:border-box;font-size:15px;font-weight:500;color:var(--primary-active)}.action-button:hover,.action-button:active{background-color:#a5d8ff}.action-button svg{width:18px;height:18px;fill:currentColor;flex-shrink:0}@media (max-width: 768px){.action-button{padding:10px 20px;font-size:13px;min-height:40px}.action-button svg{width:16px;height:16px}}.sidebar{background-color:var(--background);height:100%;width:280px;min-width:280px;padding:0;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow:hidden}.sidebar-header{padding:16px;background:var(--primary);color:#fff;margin:0;display:flex;align-items:center;justify-content:center}.sidebar-logo{color:#fff}.sidebar-logo .logo-text{color:#fff;font-weight:700}.sidebar-nav{display:flex;flex-direction:column;flex:1;padding:16px;overflow-y:auto}.sidebar-nav>.action-button{width:auto;min-height:52px;padding-left:16px;padding-right:16px;align-self:flex-start;margin-bottom:12px}.sidebar-list{list-style:none;padding:0;margin:0}.sidebar-list-button{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:none;border:none;border-radius:24px;font-size:15px;font-weight:500;color:var(--text-secondary);cursor:pointer;text-align:left;min-height:48px}.sidebar-list-button:hover{background-color:var(--surface-hover)}.sidebar-list-button.selected{background-color:var(--primary-light);color:var(--primary-active);font-weight:600}.sidebar-list-button.selected .sidebar-count-badge{color:var(--primary-active);font-weight:600}.sidebar-list-icon{width:20px;height:20px;fill:currentColor;min-width:20px;display:flex;justify-content:center;align-items:center}.sidebar-list-text{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.sidebar-count-badge{display:inline-flex;align-items:center;justify-content:center;height:auto;min-width:auto;padding:0;border-radius:0;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;margin-left:auto}.sidebar-action-container{padding:24px;margin-top:auto;display:flex;justify-content:flex-end}.sidebar-logout-button{display:flex;align-items:center;gap:12px;width:auto;padding:10px 12px;background:none;border:1px solid var(--error-border);border-radius:6px;font-size:14px;color:var(--error-text);cursor:pointer;margin-top:12px;align-self:center}.sidebar-logout-button:hover{background-color:var(--error-subtle)}@media (max-width: 768px){.sidebar,.sidebar.open{display:none}.sidebar-header{padding:16px}.sidebar-nav{padding:12px}.sidebar-action-container{padding:16px}}.contact-table-header{position:sticky;top:0;background:var(--surface-hover);z-index:10}.contact-table-header th{padding:16px 20px;text-align:left;font-weight:600;font-size:14px;color:var(--text-secondary);border-bottom:2px solid var(--border-subtle);background:var(--surface-hover)}.contact-table-header th:first-child,.contact-table-header th:nth-child(2){width:25%}.contact-table-header th:nth-child(3),.contact-table-header th:nth-child(4){width:20%}.contact-table-header th:last-child{width:10%;text-align:right}.contact-table-header-content{display:flex;align-items:center;gap:8px}.contact-table-icon{width:18px;height:18px;fill:var(--text-muted)}@media (max-width: 768px){.contact-table-header th{padding:12px 16px;font-size:13px}}@media (max-width: 480px){.contact-table-header th{padding:12px 8px;font-size:12px}}.table-actions-container{display:flex;gap:4px;justify-content:flex-end}.table-action-button{background:none;border:none;cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.table-action-button:hover{background:var(--surface-hover)}.table-action-button svg{width:18px;height:18px;fill:var(--text-muted)}.table-action-button.favorite svg{fill:var(--warning)}.table-action-button.favorite-empty svg{fill:var(--text-subtle)}.table-action-button.edit:hover svg{fill:var(--primary)}.table-action-button.delete:hover{background:var(--error-light)}.table-action-button.delete:hover svg{fill:var(--error)}.table-action-button.favorite:hover{background:var(--warning-light)}.contact-table-row{height:72px;cursor:pointer;border-bottom:1px solid var(--border-light)}.contact-table-row:hover{background-color:var(--surface-hover)}.contact-table-row:last-child{border-bottom:none}.contact-table-cell{padding:16px 20px;vertical-align:middle;font-size:14px;color:var(--text-secondary)}.contact-table-cell:last-child{text-align:right}.contact-info{display:flex;align-items:center;gap:12px}.contact-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px}.contact-name{font-weight:600;color:var(--text-primary);font-size:15px}.contact-email,.contact-phone,.contact-company{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.contact-phone{font-family:Courier New,monospace}@media (max-width: 768px){.contact-table-cell{padding:12px 16px}.contact-info{gap:8px}.contact-avatar{width:36px;height:36px;font-size:12px}.contact-name{font-size:14px}.contact-email,.contact-phone,.contact-company{font-size:13px;max-width:150px}}@media (max-width: 480px){.contact-table-cell{padding:8px}}.contact-compact-list{display:none;background:#fff;overflow-y:auto;-webkit-overflow-scrolling:touch}.contact-compact-item{border-bottom:1px solid var(--border-light)}.contact-compact-item:last-child{border-bottom:none}.contact-compact-main{display:flex;align-items:center;padding:16px 20px;cursor:pointer;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent}.contact-compact-main:hover{background:var(--surface-hover)}.contact-compact-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0;margin-right:16px}.contact-compact-info{flex:1;min-width:0}.contact-compact-name{font-weight:600;color:var(--text-primary);font-size:16px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-compact-primary{font-size:14px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-compact-phone{font-family:Courier New,monospace}.contact-compact-toggle{color:var(--text-secondary);display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;margin-left:8px}.contact-compact-expanded{padding:16px 20px;border-top:1px solid var(--border-light);background:var(--oc-gray-0)}.contact-compact-details{margin-bottom:16px}.contact-compact-detail-item{display:flex;align-items:center;gap:12px;margin-bottom:8px}.contact-compact-detail-item:last-child{margin-bottom:0}.contact-compact-detail-label{color:var(--text-secondary);font-size:13px;font-weight:500;min-width:70px;flex-shrink:0}.contact-compact-detail-value{color:var(--text-primary);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.contact-compact-actions{display:flex;justify-content:flex-end}.avatar-blue{background-color:var(--avatar-blue)}.avatar-violet{background-color:var(--avatar-violet)}.avatar-red{background-color:var(--avatar-red)}.avatar-teal{background-color:var(--avatar-teal)}.avatar-cyan{background-color:var(--avatar-cyan)}.avatar-green{background-color:var(--avatar-green)}.avatar-orange{background-color:var(--avatar-orange)}.avatar-grape{background-color:var(--avatar-grape)}.avatar-indigo{background-color:var(--avatar-indigo)}.avatar-pink{background-color:var(--avatar-pink)}@media (max-width: 768px){.contact-compact-list{display:block}}@media (max-width: 480px){.contact-compact-main{padding:14px 16px}.contact-compact-avatar{width:36px;height:36px;font-size:13px;margin-right:14px}.contact-compact-name{font-size:15px}.contact-compact-primary{font-size:13px}.contact-compact-expanded{padding:14px 16px}.contact-compact-detail-value{font-size:13px}}.table-loader-container{height:100%;overflow:auto}.table-loading-container{height:100%;overflow:hidden;background:#fffffff2;border-radius:12px;border:1px solid rgba(0,0,0,.08);padding:24px;box-shadow:0 4px 20px #00000014}.table-loading-item{display:flex;align-items:center;gap:12px;margin-bottom:16px}.skeleton{background:var(--border-light)}.skeleton-circle{border-radius:50%}.skeleton-text{border-radius:4px;height:16px}.skeleton-text-large{height:20px;margin-bottom:4px}@media (max-width: 768px){.table-loading-container{padding:16px}.table-loading-item{gap:8px}}@media (max-width: 480px){.table-loading-container{padding:16px}}.no-contacts-container{height:100%;overflow:auto}.contact-empty-state{height:100%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;padding:48px;text-align:center;background:#fffffff2;border-radius:12px;border:1px solid rgba(0,0,0,.08);box-shadow:0 4px 20px #00000014}.contact-empty-icon{width:64px;height:64px;fill:var(--border-subtle);margin-bottom:8px}.contact-empty-title{font-size:18px;font-weight:600;color:var(--text-muted);margin:0 0 8px}.contact-empty-description{font-size:14px;color:var(--text-muted);max-width:400px;line-height:1.5;margin:0}.contact-empty-actions{margin-top:8px}.contact-empty-actions .action-button{width:auto;min-width:200px}@media (max-width: 480px){.contact-empty-state{padding:24px 16px}.contact-empty-actions .action-button{min-width:0;width:100%}}.delete-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.delete-modal-content{background:#fff;border-radius:8px;border:1px solid var(--border);max-width:400px;width:100%;box-shadow:0 4px 12px #0000001a}.delete-modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border-light)}.delete-modal-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.delete-modal-body{padding:16px 24px 20px}.delete-modal-text{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}.delete-modal-actions{padding:16px 24px 20px;display:flex;gap:12px;justify-content:flex-end}.delete-modal-button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.delete-modal-button-cancel{background:#fff;color:var(--text-secondary);border:1px solid var(--border-subtle)}.delete-modal-button-cancel:hover{background:var(--surface-hover)}.delete-modal-button-delete{background:var(--error);color:#fff}.delete-modal-button-delete:hover{background:var(--error-hover)}@media (max-width: 768px){.delete-modal-content{margin:8px}.delete-modal-actions{flex-direction:column}.delete-modal-button{width:100%;justify-content:center}}.contact-table-container{min-height:0;overflow:hidden;background-color:#fff}.contact-table-card{border-radius:12px;background:#fff;border:1px solid rgba(0,0,0,.08);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000014}.contact-table{width:100%;border-collapse:collapse;display:flex;flex-direction:column;background:#fff}.contact-table thead{flex-shrink:0;background:#fff}.contact-table tbody{flex:1;overflow-y:auto;display:block;min-height:0;max-height:calc(100vh - 180px);background:#fff}.contact-table thead tr,.contact-table tbody tr{display:table;width:100%;table-layout:fixed;background:#fff}.contact-table th,.contact-table td{text-align:left;vertical-align:middle}.contact-table tbody td:first-child,.contact-table tbody td:nth-child(2){width:25%}.contact-table tbody td:nth-child(3),.contact-table tbody td:nth-child(4){width:20%}.contact-table tbody td:last-child{width:10%;text-align:right}@media (max-width: 768px){.contact-table-container{display:none}}.search-container{display:flex;justify-content:flex-start;align-items:center}.search-input-container{position:relative;max-width:500px;min-width:400px;display:flex;align-items:center}.search-input{width:100%;padding:12px 16px 12px 48px;border:1px solid var(--border);border-radius:6px;font-size:16px;font-weight:400;background:#fff;box-sizing:border-box;transition:all .2s ease}.search-input:hover{border-color:var(--primary)}.search-input:focus{outline:none;border-color:var(--primary);border-width:2px;padding-left:47px}.search-input::placeholder{color:var(--text-subtle)}.search-icon{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;fill:var(--primary);pointer-events:none}.search-clear-button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.search-clear-button:hover{color:var(--error);background:var(--surface-hover)}.search-clear-button svg{width:18px;height:18px;fill:currentColor}@media (max-width: 768px){.search-container{width:100%}.search-input-container{min-width:0;max-width:100%;width:100%}.search-input{padding:10px 14px 10px 44px;font-size:16px}.search-input:focus{padding-left:43px}.search-icon{left:14px;width:18px;height:18px}}@media (max-width: 480px){.search-input-container{min-width:0}.search-input{padding:8px 12px 8px 40px;font-size:16px}.search-input:focus{padding-left:39px}.search-icon{left:12px;width:16px;height:16px}}.avatar{width:36px;height:36px;border-radius:999px;border:1px solid var(--border);background:var(--surface);display:inline-flex;align-items:center;justify-content:center;cursor:pointer;padding:0;transition:background .15s ease,border-color .15s ease}.avatar:hover{background:var(--surface-hover);border-color:var(--border-light)}.avatar.small{width:28px;height:28px}.avatar.medium{width:36px;height:36px}.avatar.large{width:44px;height:44px}.avatar-image{width:100%;height:100%;border-radius:999px;object-fit:cover}.avatar-initials{font-size:14px;font-weight:600;color:var(--text-secondary)}.user-menu{position:relative}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-sizing:border-box;padding:8px;z-index:1000}.user-menu-header{padding:8px 10px 10px}.user-menu-greeting{font-weight:700;color:var(--text-primary);margin-bottom:4px}.user-menu-label{font-size:12px;color:var(--text-subtle);margin-bottom:2px}.user-menu-email{font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-menu-greeting-mobile{display:none;font-weight:600;color:var(--text-secondary);margin-bottom:8px;font-size:16px}.user-menu-separator{height:1px;background:var(--border-light);margin:6px 4px}.user-menu-item{width:100%;text-align:left;background:none;border:none;padding:8px 10px;border-radius:6px;color:var(--text-primary);cursor:pointer}.user-menu-item:hover{background:var(--surface-hover)}.user-menu-item.danger{color:var(--error)}.user-menu-item.danger:hover{background:var(--error-subtle)}@media (max-width: 1024px){.user-menu-dropdown{right:8px;left:auto;min-width:220px}.user-menu-greeting-mobile{display:block}}.add-button{width:44px;height:44px;border-radius:50%;border:none;background:var(--primary-light);color:var(--primary-active);cursor:pointer;display:none;align-items:center;justify-content:center;font-size:20px;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent}.add-button ion-icon{color:var(--primary-active);font-size:20px}.add-button:hover,.add-button:active{background:#a5d8ff}@media (max-width: 768px){.add-button{display:flex;width:40px;height:40px;font-size:18px}.add-button ion-icon{color:var(--primary-active);font-size:18px}}@media (max-width: 480px){.add-button{width:36px;height:36px;font-size:16px}.add-button ion-icon{color:var(--primary-active);font-size:16px}}.tab-toggle{display:none;background:transparent;border-radius:8px;padding:0;gap:8px;width:fit-content}.tab-toggle-button{display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;border-radius:16px;background:none;color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;-webkit-tap-highlight-color:transparent;text-align:left;min-height:36px}.tab-toggle-button:hover{background-color:var(--surface-hover)}.tab-toggle-button.active{background-color:var(--primary-light);color:var(--primary-active);font-weight:600}.tab-toggle-button ion-icon{width:16px;height:16px;fill:currentColor;min-width:16px;display:flex;justify-content:center;align-items:center}@media (max-width: 768px){.tab-toggle{display:flex;width:100%;gap:4px}.tab-toggle-button{flex:1;justify-content:center;padding:10px 14px;min-height:40px}}@media (max-width: 480px){.tab-toggle-button{padding:8px 10px;font-size:13px;gap:6px}.tab-toggle-button ion-icon{width:14px;height:14px}}.mainview{flex:1;height:100%;background:var(--background);display:flex;flex-direction:column;overflow:hidden}.mainview-container{display:flex;flex-direction:column;gap:24px;padding:24px 32px;max-width:none;margin:0 auto;width:100%;box-sizing:border-box}.mainview-topbar{display:flex;align-items:center;justify-content:space-between}.mainview-search-section{display:flex;align-items:center;gap:12px;flex:1}.mainview-controls{opacity:1}.mainview-right-actions{display:flex;align-items:center;gap:12px}.mainview-greeting{color:var(--text-secondary);font-weight:600}.mainview-section{opacity:1}.mainview-table-section{flex:1;overflow:hidden;min-height:0;display:flex;flex-direction:column}@media (max-width: 1024px){.mainview-greeting{display:none}}@media (max-width: 768px){.mainview{margin-left:0;width:100%}.mainview-container{padding:16px;gap:16px}.mainview-topbar{flex-direction:column;gap:12px;align-items:stretch}.mainview-search-section{gap:8px}.mainview-right-actions{justify-content:flex-end}.mainview-right-actions .user-menu{display:none}.mainview-table-section{flex:1;overflow:hidden}}@media (max-width: 480px){.mainview-container{padding:12px;gap:12px}.mainview-topbar{gap:8px}}.mobile-header{display:none;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--primary);border-bottom:1px solid var(--border);position:relative;z-index:100}.mobile-header-logo{flex:0;display:flex;justify-content:flex-start}.mobile-header-user{flex:0;display:flex;align-items:center}.mobile-header-user .user-menu{height:auto}.mobile-header-user .avatar{width:36px;height:36px;max-width:36px;max-height:36px}.mobile-header-logo-style{color:#fff}.mobile-header-logo-style .logo-text{color:#fff;font-weight:700}@media (max-width: 768px){.mobile-header{display:flex}}@media (max-width: 480px){.mobile-header{padding:14px 16px}.mobile-header-user .avatar{width:32px;height:32px;max-width:32px;max-height:32px}}:root{--background: #f8f9fa;--surface: #ffffff;--surface-hover: #f1f3f5;--border: #dee2e6;--border-light: #e9ecef;--border-subtle: #ced4da;--text-primary: #212529;--text-secondary: #495057;--text-muted: #868e96;--text-subtle: #adb5bd;--primary: #228be6;--primary-hover: #1c7ed6;--primary-active: #1971c2;--primary-light: #d0ebff;--primary-subtle: #e7f5ff;--error: #fa5252;--error-hover: #f03e3e;--error-light: #ffe3e3;--error-subtle: #fff5f5;--error-text: #c92a2a;--error-border: #ffa8a8;--success: #40c057;--success-light: #d3f9d8;--success-subtle: #ebfbee;--success-text: #2b8a3e;--success-border: #8ce99a;--warning: #fab005;--warning-light: #ffe8cc;--warning-subtle: #fff4e6;--avatar-blue: #228be6;--avatar-violet: #7950f2;--avatar-red: #ff6b6b;--avatar-teal: #12b886;--avatar-cyan: #15aabf;--avatar-green: #40c057;--avatar-orange: #fd7e14;--avatar-grape: #be4bdb;--avatar-indigo: #4c6ef5;--avatar-pink: #e64980}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}
