:root{--header-height:56px;--sidebar-width:220px;--sidebar-collapsed-width:56px;--color-background:#f5f6fa;--color-surface:#fff;--color-border:#e5e7eb;--color-hover:#f3f4f6;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#dbeafe;--color-text:#111827;--color-text-secondary:#6b7280;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-danger-light:#fee2e2;--color-success:#16a34a;--color-warning:#d97706;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 4px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--transition-fast:.15s ease;--transition-base:.22s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--color-background:#0f1117;--color-surface:#1a1d27;--color-border:#2d3048;--color-hover:#252840;--color-primary-light:#1e3a5f;--color-text:#f1f5f9;--color-text-secondary:#8892a4;--color-danger-light:#3f1515;--shadow-sm:0 1px 4px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 8px 32px #00000080}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}html,body{overflow-x:hidden}body{font-feature-settings:"cv02", "cv03", "cv04", "cv11";-webkit-font-smoothing:antialiased;background:var(--color-background);color:var(--color-text);transition:background var(--transition-slow), color var(--transition-slow);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}:focus:not(:focus-visible){outline:none}.skip-link{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);z-index:9999;padding:.5rem 1rem;font-size:.875rem;font-weight:600;transition:top .15s;position:absolute;top:-100%;left:1rem}.skip-link:focus{outline-offset:2px;outline:2px solid #fff;top:.75rem}.page-loader{background:var(--color-background);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.page-loader:after{content:"";border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite page-spin}@keyframes page-spin{to{transform:rotate(360deg)}}.form-grid{flex-direction:column;gap:1rem;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:.75rem;display:grid}.form-row--3{grid-template-columns:2fr 1fr 1fr}@media (width<=480px){.form-row,.form-row--3{grid-template-columns:1fr}}@media (width<=767px){html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%}}.btn{border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast), opacity var(--transition-fast), transform .1s ease;vertical-align:middle;border:1px solid #0000;justify-content:center;align-items:center;gap:.5rem;font-family:inherit;font-weight:500;line-height:1;text-decoration:none;display:inline-flex}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.55;cursor:not-allowed;pointer-events:none}.btn--sm{gap:.375rem;padding:.375rem .75rem;font-size:.8125rem}.btn--md{padding:.5625rem 1rem;font-size:.875rem}.btn--lg{padding:.75rem 1.25rem;font-size:.9375rem}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn--primary:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-hover);border-color:var(--color-text-secondary)}.btn--secondary:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light)}.btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--danger:hover:not(:disabled){background:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn--danger:focus-visible{box-shadow:0 0 0 3px var(--color-danger-light)}.btn--ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn--ghost:hover:not(:disabled){background:var(--color-hover);color:var(--color-text)}.btn--ghost:focus-visible{box-shadow:0 0 0 3px var(--color-primary-light)}.btn__icon{flex-shrink:0;align-items:center;display:inline-flex}.btn__icon svg{width:1em;height:1em}.btn--loading{position:relative}.btn__spinner{border:2px solid;border-top-color:#0000;border-radius:50%;flex-shrink:0;width:.875em;height:.875em;animation:.65s linear infinite btn-spin}@keyframes btn-spin{to{transform:rotate(360deg)}}.error-boundary{background:var(--color-background);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.error-boundary__content{text-align:center;max-width:400px}.error-boundary__title{color:var(--color-text);margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.error-boundary__message{color:var(--color-text-secondary);word-break:break-word;margin-bottom:1.5rem;font-size:.875rem}.spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;flex-shrink:0;animation:.65s linear infinite spinner-rotate;display:inline-block}.spinner--sm{width:16px;height:16px}.spinner--md{width:24px;height:24px}.spinner--lg{border-width:3px;width:36px;height:36px}@keyframes spinner-rotate{to{transform:rotate(360deg)}}.badge{white-space:nowrap;border:1px solid #0000;border-radius:999px;align-items:center;padding:.2em .6em;font-size:.75rem;font-weight:500;line-height:1;display:inline-flex}.badge--default{background:var(--color-hover);color:var(--color-text-secondary);border-color:var(--color-border)}.badge--primary{background:var(--color-primary-light);color:var(--color-primary)}.badge--success{color:#15803d;background:#dcfce7}[data-theme=dark] .badge--success{color:#4ade80;background:#14532d}.badge--warning{color:#a16207;background:#fef9c3}[data-theme=dark] .badge--warning{color:#fbbf24;background:#422006}.badge--danger{background:var(--color-danger-light);color:var(--color-danger)}.badge--outline{color:var(--color-text-secondary);border-color:var(--color-border);background:0 0}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:box-shadow var(--transition-base);padding:1.5rem}.card--no-padding{padding:0;overflow:hidden}.card__header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem;display:flex}.card:not(.card--no-padding) .card__header{border-bottom:1px solid var(--color-border);margin-bottom:1.25rem;padding:0 0 1.25rem}.card__header-text{min-width:0}.card__title{color:var(--color-text);margin:0;font-size:.9375rem;font-weight:600;line-height:1.3}.card__description{color:var(--color-text-secondary);margin:.2rem 0 0;font-size:.8125rem}.card__header-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.card--no-padding .card__body{padding:1.25rem 1.5rem}.card__footer{border-top:1px solid var(--color-border);justify-content:flex-end;align-items:center;gap:.5rem;margin-top:1.25rem;padding-top:1.25rem;display:flex}.card--no-padding .card__footer{margin-top:0;padding:1rem 1.5rem}@media (width<=480px){.card{padding:1.25rem}.card--no-padding .card__header,.card--no-padding .card__body,.card--no-padding .card__footer{padding-left:1rem;padding-right:1rem}.card__header{flex-wrap:wrap}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:3rem 1.5rem;display:flex}.empty-state__icon{color:var(--color-text-secondary);opacity:.4;margin-bottom:.75rem}.empty-state__icon svg{width:56px;height:56px}.empty-state__title{color:var(--color-text);margin:0;font-size:.9375rem;font-weight:600}.empty-state__description{color:var(--color-text-secondary);max-width:320px;margin:0;font-size:.875rem}.empty-state__action{margin-top:.75rem}.error-banner{background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md);align-items:flex-start;gap:.625rem;margin-bottom:1rem;padding:.75rem 1rem;display:flex}.error-banner__icon{width:1.125rem;height:1.125rem;color:var(--color-danger);flex-shrink:0;margin-top:1px}.error-banner__message{color:var(--color-danger);margin:0;font-size:.875rem;line-height:1.5}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{border-radius:var(--radius-sm);background:linear-gradient(90deg, var(--color-border) 25%, var(--color-hover) 50%, var(--color-border) 75%);background-size:200% 100%;animation:1.6s ease-in-out infinite skeleton-shimmer;display:inline-block}.skeleton--circle{border-radius:50%}.skeleton-group{flex-direction:column;width:100%;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(3px);z-index:900;animation:modal-overlay-in var(--transition-fast) forwards;background:#00000073;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);width:100%;max-height:calc(100vh - 2rem);animation:modal-in var(--transition-base) forwards;outline:none;flex-direction:column;display:flex}@keyframes modal-in{0%{opacity:0;transform:scale(.96)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal--sm{max-width:400px}.modal--md{max-width:560px}.modal--lg{max-width:760px}.modal__header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:1rem;padding:1.25rem 1.5rem 1rem;display:flex}.modal__header-text{min-width:0}.modal__title{color:var(--color-text);letter-spacing:-.01em;margin:0;font-size:1.0625rem;font-weight:700}.modal__description{color:var(--color-text-secondary);margin:.25rem 0 0;font-size:.8125rem}.modal__close{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.modal__close:hover{background:var(--color-hover);color:var(--color-text)}.modal__close svg{width:16px;height:16px}.modal__body{flex:1;padding:1.25rem 1.5rem;overflow-y:auto}.modal__footer{border-top:1px solid var(--color-border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:.625rem;padding:1rem 1.5rem;display:flex}@media (width<=480px){.modal-overlay{align-items:flex-end;padding:0}.modal{border-bottom-right-radius:0;border-bottom-left-radius:0;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);max-height:92vh;animation:modal-slide-up var(--transition-base) forwards}.modal__header:before{content:"";background:var(--color-border);border-radius:2px;width:2.5rem;height:4px;position:absolute;top:.5rem;left:50%;transform:translate(-50%)}.modal__header{padding-top:1.5rem;position:relative}.modal__footer{flex-direction:column-reverse;gap:.5rem}.modal__footer>*{justify-content:center;width:100%}}@keyframes modal-slide-up{0%{opacity:.6;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}.table-wrapper{-webkit-overflow-scrolling:touch;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%;color:var(--color-text);font-size:.875rem}.table__caption{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.table__head{background:var(--color-hover);border-bottom:1px solid var(--color-border);z-index:2;position:sticky;top:0}.table__th{text-align:left;color:var(--color-text-secondary);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;-webkit-user-select:none;user-select:none;padding:.6875rem 1rem;font-size:.75rem;font-weight:600}.table__th-inner{align-items:center;gap:.375rem;display:inline-flex}.table__th--sortable{cursor:pointer}.table__th--sortable:hover{color:var(--color-text)}.table__th--active{color:var(--color-primary)}.table__sort-icon{flex-shrink:0;align-items:center;display:inline-flex}.table__sort-icon svg{width:14px;height:14px}.table__body .table__row{border-bottom:1px solid var(--color-border);transition:background var(--transition-fast)}.table__body .table__row:nth-child(2n){background:color-mix(in srgb, var(--color-hover) 50%, transparent)}.table__body .table__row:last-child{border-bottom:none}.table__body .table__row:hover{background:var(--color-hover)}.table__row--clickable{cursor:pointer}.table__row--clickable:focus-visible{outline:2px solid var(--color-primary);outline-offset:-2px}.table__td{vertical-align:middle;color:var(--color-text);padding:.875rem 1rem}.table__cell--left{text-align:left}.table__cell--center{text-align:center}.table__cell--right{text-align:right}.table__empty{text-align:center;border-top:1px solid var(--color-border);padding:3rem 1.5rem}.input-field{flex-direction:column;gap:.375rem;display:flex}.input-field__label-row{justify-content:space-between;align-items:center;display:flex}.input-field__label-row--single{display:block}.input-field__label{color:var(--color-text);font-size:.8125rem;font-weight:500}.input-field__label-action{align-items:center;display:flex}.input-field__wrapper{width:100%;display:flex}.input-field__inner{flex:1;align-items:center;display:flex;position:relative}.input-field__addon{background:var(--color-hover);border:1px solid var(--color-border);color:var(--color-text-secondary);white-space:nowrap;flex-shrink:0;align-items:center;padding:0 .625rem;font-size:.875rem;display:inline-flex}.input-field__addon--prefix{border-radius:var(--radius-sm) 0 0 var(--radius-sm);border-right:none}.input-field__addon--suffix{border-radius:0 var(--radius-sm) var(--radius-sm) 0;border-left:none}.input-field__icon{pointer-events:none;color:var(--color-text-secondary);align-items:center;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.input-field__icon svg,.input-field__icon>*{width:16px;height:16px}.input-field__icon--left{left:.625rem}.input-field__icon--right{right:.625rem}.input-field__input{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.5625rem .75rem;font-family:inherit;font-size:.875rem}.input-field__input--icon-left{padding-left:2.125rem}.input-field__input--icon-right{padding-right:2.125rem}.input-field__input--no-left-radius{border-radius:0 var(--radius-sm) var(--radius-sm) 0}.input-field__input--no-right-radius{border-radius:var(--radius-sm) 0 0 var(--radius-sm)}.input-field__input::placeholder{color:var(--color-text-secondary);opacity:.7}.input-field__input:hover:not(:disabled):not(:focus){border-color:var(--color-text-secondary)}.input-field__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input-field__input:disabled{opacity:.55;cursor:not-allowed;background:var(--color-hover)}.input-field__input--error{border-color:var(--color-danger)!important}.input-field__input--error:focus{box-shadow:0 0 0 3px #dc262626!important}.input-field__hint{color:var(--color-text-secondary);margin:0;font-size:.75rem}.input-field__error{color:var(--color-danger);margin:0;font-size:.75rem}@media (width<=767px){.input-field__input,.select-field__select{font-size:1rem}}.select-field{flex-direction:column;gap:.375rem;display:flex}.select-field__label{color:var(--color-text);font-size:.8125rem;font-weight:500}.select-field__wrapper{align-items:center;display:flex;position:relative}.select-field__select{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);background:var(--color-surface);appearance:none;cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.5625rem 2.25rem .5625rem .75rem;font-family:inherit;font-size:.875rem}.select-field__select:hover:not(:disabled):not(:focus){border-color:var(--color-text-secondary)}.select-field__select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.select-field__select:disabled{opacity:.55;cursor:not-allowed;background:var(--color-hover)}.select-field__select--error{border-color:var(--color-danger)!important}.select-field__select--error:focus{box-shadow:0 0 0 3px #dc262626!important}.select-field__chevron{pointer-events:none;color:var(--color-text-secondary);align-items:center;display:flex;position:absolute;right:.625rem}.select-field__chevron svg{width:16px;height:16px}.select-field__hint{color:var(--color-text-secondary);margin:0;font-size:.75rem}.select-field__error{color:var(--color-danger);margin:0;font-size:.75rem}@media (width<=767px){.select-field__select{font-size:1rem}}.textarea-field{flex-direction:column;gap:.375rem;display:flex}.textarea-field__label{color:var(--color-text);font-size:.8125rem;font-weight:500}.textarea-field__textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;min-height:96px;color:var(--color-text);background:var(--color-surface);resize:vertical;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;padding:.5625rem .75rem;font-family:inherit;font-size:.875rem;line-height:1.5}.textarea-field__textarea::placeholder{color:var(--color-text-secondary);opacity:.7}.textarea-field__textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.textarea-field__textarea:disabled{opacity:.55;cursor:not-allowed;background:var(--color-hover);resize:none}.textarea-field__textarea--error{border-color:var(--color-danger)!important}.textarea-field__textarea--error:focus{box-shadow:0 0 0 3px #dc262626!important}.textarea-field__hint{color:var(--color-text-secondary);margin:0;font-size:.75rem}.textarea-field__error{color:var(--color-danger);margin:0;font-size:.75rem}@media (width<=767px){.textarea-field__textarea{font-size:1rem}}.tooltip{align-items:center;display:inline-flex;position:relative}.tooltip:after{content:attr(data-tooltip);z-index:800;white-space:nowrap;border-radius:var(--radius-sm);color:#f1f5f9;pointer-events:none;opacity:0;background:#1a1d27;padding:.3125rem .625rem;font-size:.75rem;font-weight:500;line-height:1.4;transition:opacity .15s,transform .15s;position:absolute;transform:translateY(4px)}[data-theme=light] .tooltip:after{color:#f1f5f9;background:#1a1d27}[data-theme=dark] .tooltip:after{color:#1a1d27;background:#e2e8f0}.tooltip:before{content:"";z-index:801;pointer-events:none;opacity:0;width:0;height:0;transition:opacity .15s;position:absolute}.tooltip:hover:after,.tooltip:hover:before,.tooltip:focus-within:after,.tooltip:focus-within:before{opacity:1}.tooltip:hover:after,.tooltip:focus-within:after{transform:translateY(0)}.tooltip--top:after{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(4px)}.tooltip--top:hover:after,.tooltip--top:focus-within:after{transform:translate(-50%)translateY(0)}.tooltip--top:before{border:5px solid #0000;border-top-color:#1a1d27;bottom:calc(100% + 2px);left:50%;transform:translate(-50%)}[data-theme=dark] .tooltip--top:before{border-top-color:#e2e8f0}.tooltip--bottom:after{top:calc(100% + 8px);left:50%;transform:translate(-50%)translateY(-4px)}.tooltip--bottom:hover:after,.tooltip--bottom:focus-within:after{transform:translate(-50%)translateY(0)}.tooltip--bottom:before{border:5px solid #0000;border-bottom-color:#1a1d27;top:calc(100% + 2px);left:50%;transform:translate(-50%)}[data-theme=dark] .tooltip--bottom:before{border-bottom-color:#e2e8f0}.tooltip--left:after{top:50%;right:calc(100% + 8px);transform:translateY(-50%)translate(4px)}.tooltip--left:hover:after,.tooltip--left:focus-within:after{transform:translateY(-50%)translate(0)}.tooltip--left:before{border:5px solid #0000;border-left-color:#1a1d27;top:50%;right:calc(100% + 2px);transform:translateY(-50%)}[data-theme=dark] .tooltip--left:before{border-left-color:#e2e8f0}.tooltip--right:after{top:50%;left:calc(100% + 8px);transform:translateY(-50%)translate(-4px)}.tooltip--right:hover:after,.tooltip--right:focus-within:after{transform:translateY(-50%)translate(0)}.tooltip--right:before{border:5px solid #0000;border-right-color:#1a1d27;top:50%;left:calc(100% + 2px);transform:translateY(-50%)}[data-theme=dark] .tooltip--right:before{border-right-color:#e2e8f0}.checkbox-field{flex-direction:column;gap:.25rem;display:flex}.checkbox-field--disabled{opacity:.5;pointer-events:none}.checkbox-field__control{align-items:center;gap:.5rem;display:flex}.checkbox-field__input{appearance:none;border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:1rem;height:1rem;transition:background var(--transition-fast), border-color var(--transition-fast);border-radius:4px;flex-shrink:0;position:relative}.checkbox-field__input:checked{background:var(--color-primary);border-color:var(--color-primary)}.checkbox-field__input:checked:after{content:"";background:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 5l3.5 3.5L11 1' stroke='white' stroke-width='1.75' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") 50%/10px no-repeat;position:absolute;inset:0}.checkbox-field__input--error{border-color:var(--color-danger)}.checkbox-field__input:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.checkbox-field__input:hover:not(:disabled){border-color:var(--color-primary)}.checkbox-field__input:indeterminate{background:var(--color-primary);border-color:var(--color-primary)}.checkbox-field__input:indeterminate:after{content:"";background:url("data:image/svg+xml,%3Csvg viewBox='0 0 12 2' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1h10' stroke='white' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") 50%/10px no-repeat;position:absolute;inset:0}.checkbox-field__label{color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.875rem}.checkbox-field__hint{color:var(--color-text-secondary);padding-left:1.5rem;font-size:.75rem}.checkbox-field__error{color:var(--color-danger);padding-left:1.5rem;font-size:.75rem}.auth-loader{background:var(--color-background);justify-content:center;align-items:center;min-height:100vh;display:flex}.header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;box-shadow:var(--shadow-sm);transition:background var(--transition-slow), border-color var(--transition-slow), right .25s cubic-bezier(.4, 0, .2, 1);justify-content:space-between;align-items:center;padding:0 1.25rem;display:flex;position:fixed;top:0;left:0;right:3rem}body.phone-disabled .header{right:0}body.phone-sidebar-open .header{right:22rem}.header__left{align-items:center;gap:.875rem;min-width:0;display:flex}.header__menu-btn{cursor:pointer;border-radius:var(--radius-sm);width:2rem;height:2rem;transition:background var(--transition-fast);background:0 0;border:none;flex-direction:column;flex-shrink:0;justify-content:center;gap:5px;padding:4px;display:flex}.header__menu-btn:hover{background:var(--color-hover)}.hamburger-line{background:var(--color-text-secondary);width:18px;height:2px;transition:background var(--transition-fast);border-radius:2px;display:block}.header__menu-btn:hover .hamburger-line{background:var(--color-text)}.header__logo{object-fit:contain;object-position:center;width:auto;max-width:min(38vw,10rem);height:clamp(1.75rem,2.5vw,2rem);margin-top:-4px;margin-bottom:-4px;display:block}[data-theme=dark] .header__logo{filter:invert()}.header__right{align-items:center;gap:.25rem;display:flex}.header__icon-btn{border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;color:var(--color-text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.header__icon-btn:hover{background:var(--color-hover);color:var(--color-text)}.header__icon-btn svg{width:1.125rem;height:1.125rem}.header__user-menu{margin-left:.25rem;position:relative}.header__avatar{background:var(--color-primary);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;width:2rem;height:2rem;transition:opacity var(--transition-fast), box-shadow var(--transition-fast);letter-spacing:0;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.8125rem;font-weight:700;display:flex}.header__avatar:hover{opacity:.9;box-shadow:0 0 0 3px var(--color-primary-light)}.header__dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-width:220px;box-shadow:var(--shadow-lg);z-index:200;padding:.75rem;animation:.15s cubic-bezier(.4,0,.2,1) dropdownIn;position:absolute;top:calc(100% + .5rem);right:0}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.header__dropdown-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-bottom:.125rem;padding:0 .25rem;font-size:.875rem;font-weight:600;overflow:hidden}.header__dropdown-email{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;padding:0 .25rem;font-size:.75rem;overflow:hidden}.header__dropdown-divider{border:none;border-top:1px solid var(--color-border);margin:.5rem 0}.header__dropdown-item{border-radius:var(--radius-sm);width:100%;color:var(--color-text);cursor:pointer;text-align:left;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;padding:.5rem;font-size:.875rem;font-weight:500;display:flex}.header__dropdown-item:hover{background:var(--color-hover)}.header__dropdown-item--danger{color:var(--color-danger)}.header__dropdown-item--danger:hover{background:var(--color-danger-light);color:var(--color-danger-hover)}@media (width<=640px){.header{padding:0 .875rem}.header__left{gap:.625rem}.header__logo{max-width:min(42vw,8rem);height:clamp(1.5rem,6vw,1.75rem)}}.sidebar__drawer-header{display:none}.sidebar{top:var(--header-height);width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);z-index:90;flex-direction:column;transition:width .22s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;bottom:0;left:0;overflow:hidden}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar--collapsed .sidebar__label{display:none}.sidebar__nav{flex-direction:column;flex:1;padding:.5rem 0;display:flex;overflow:hidden auto}.sidebar__section{border-top:1px solid var(--color-border);margin-top:auto;padding-top:.5rem}.sidebar__section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-secondary);opacity:.6;white-space:nowrap;padding:.5rem .75rem .25rem;font-size:.65rem;font-weight:700;display:block;overflow:hidden}.sidebar--collapsed .sidebar__section-label{opacity:0}.sidebar__list{margin:0;padding:0;list-style:none}.sidebar__link{border-radius:var(--radius-sm);color:var(--color-text-secondary);white-space:nowrap;align-items:center;gap:.75rem;padding:.6rem .75rem;font-size:.875rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar__link:hover{background:var(--color-hover);color:var(--color-text)}.sidebar__link--active{background:var(--color-primary-light);color:var(--color-primary);position:relative}.sidebar__link--active:before{content:"";background:var(--color-primary);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:-.5rem;transform:translateY(-50%)}.sidebar__link--active:hover{background:var(--color-primary-light);color:var(--color-primary)}.sidebar__icon{flex-shrink:0;justify-content:center;align-items:center;width:1.125rem;height:1.125rem;display:flex}.sidebar__icon svg{width:100%;height:100%}.sidebar__label{text-overflow:ellipsis;transition:opacity .15s;overflow:hidden}.sidebar__item{margin-bottom:2px;padding:0 .5rem;position:relative}.sidebar--collapsed .sidebar__item:after{content:attr(data-tooltip);left:calc(var(--sidebar-collapsed-width) + 4px);background:var(--color-text);color:var(--color-surface);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;z-index:200;box-shadow:var(--shadow-md);padding:.3125rem .625rem;font-size:.8125rem;font-weight:500;transition:opacity .15s;position:absolute;top:50%;transform:translateY(-50%)}.sidebar--collapsed .sidebar__item:hover:after{opacity:1}@media (width<=767px){.sidebar{z-index:300;border-right:none;transition:transform .3s cubic-bezier(.4,0,.2,1);top:0;overflow:visible;transform:translate(-105%);box-shadow:2px 0 8px #00000014,8px 0 24px #0000001f,24px 0 48px #00000014;width:min(300px,85vw)!important}.sidebar--mobile-open{transform:translate(0)}.sidebar__drawer-header{height:var(--header-height);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:0 1rem 0 1.25rem;display:flex}.sidebar__drawer-brand{color:var(--color-text);letter-spacing:-.01em;font-size:1rem;font-weight:700}.sidebar__close-btn{border-radius:var(--radius-sm);width:2.25rem;height:2.25rem;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.sidebar__close-btn:hover{background:var(--color-hover);color:var(--color-text)}.sidebar__close-btn svg{width:1.125rem;height:1.125rem}.sidebar--collapsed .sidebar__label,.sidebar--mobile-open .sidebar__label{display:block}.sidebar__item{margin-bottom:2px;padding:0 .75rem}.sidebar__link{border-radius:var(--radius-md);gap:.875rem;padding:.875rem 1rem;font-size:.9375rem;position:relative}.sidebar__link--active{background:var(--color-primary-light);color:var(--color-primary)}.sidebar__link--active:before{content:"";background:var(--color-primary);border-radius:0 3px 3px 0;width:3px;height:1.5rem;position:absolute;top:50%;left:0;transform:translateY(-50%)}.sidebar__icon{width:1.25rem;height:1.25rem}.sidebar__nav{-webkit-overflow-scrolling:touch;padding:.75rem 0;overflow-y:auto}}[data-theme=dark] .sidebar{background:var(--color-surface);border-color:var(--color-border)}[data-theme=dark] .sidebar__drawer-header{border-color:var(--color-border)}@media (width<=767px){[data-theme=dark] .sidebar{box-shadow:2px 0 8px #0006,8px 0 24px #00000080,24px 0 48px #0006}}.phone-widget__sidebar{z-index:900;flex-direction:row;width:22rem;height:100vh;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:0;transform:translate(calc(100% - 3rem))}.phone-widget__sidebar--open{transform:translate(0)}.phone-widget__tab{background:var(--color-surface);border:none;border-left:1px solid var(--color-border);cursor:pointer;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:.75rem;width:3rem;height:100%;padding:0;transition:background .15s;display:flex;position:relative;box-shadow:-3px 0 12px #00000012}.phone-widget__tab:hover{background:color-mix(in srgb, var(--color-primary) 6%, var(--color-surface))}.phone-widget__sidebar--ringing .phone-widget__tab{animation:1s ease-in-out infinite tab-ring-pulse}@keyframes tab-ring-pulse{0%,to{background:var(--color-surface);box-shadow:-3px 0 12px #00000012}50%{background:color-mix(in srgb, #16a34a 12%, var(--color-surface));box-shadow:-3px 0 20px #16a34a59}}.phone-widget__tab-icon{justify-content:center;align-items:center;display:flex;transform:rotate(45deg)}.phone-widget__tab-icon svg{flex-shrink:0;width:1.25rem;height:1.25rem;transition:color .2s}.phone-widget__tab-icon--idle svg{color:var(--color-text-secondary);opacity:.5}.phone-widget__tab-icon--connecting svg{color:#f59e0b;animation:1s infinite dot-pulse}.phone-widget__tab-icon--ready svg{color:#22c55e}.phone-widget__tab-icon--error svg{color:#ef4444}.phone-widget__tab-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);writing-mode:vertical-rl;-webkit-user-select:none;user-select:none;font-size:.625rem;font-weight:600;transform:rotate(180deg)}.phone-widget__status-dot{border-radius:50%;flex-shrink:0;width:.5rem;height:.5rem;display:block}.phone-widget__status-dot--idle{background:var(--color-text-secondary);opacity:.5}.phone-widget__status-dot--connecting{background:#f59e0b;animation:1s infinite dot-pulse}.phone-widget__status-dot--ready{background:#22c55e;box-shadow:0 0 0 2px #22c55e40}.phone-widget__status-dot--error{background:#ef4444}@keyframes dot-pulse{0%,to{opacity:1}50%{opacity:.3}}.phone-widget__content{background:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;flex:1;min-width:0;display:flex;overflow:visible}.phone-widget__body{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden auto}.phone-widget__body::-webkit-scrollbar{width:4px}.phone-widget__body::-webkit-scrollbar-track{background:0 0}.phone-widget__body::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.phone-widget__header{border-bottom:1px solid var(--color-border);background:var(--color-surface);z-index:2;flex-shrink:0;align-items:center;gap:.375rem;height:3rem;padding:0 .5rem 0 .875rem;display:flex;position:relative;overflow:visible}.phone-widget__header-left{flex:1;align-items:center;gap:.5rem;min-width:0;display:flex}.phone-widget__header-title{color:var(--color-text);font-size:.875rem;font-weight:600}.phone-widget__close-btn{border-radius:var(--radius-sm,4px);cursor:pointer;width:1.625rem;height:1.625rem;color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;margin-left:.125rem;transition:color .15s,background .15s;display:flex}.phone-widget__close-btn:hover{color:var(--color-text);background:color-mix(in srgb, var(--color-text) 8%, transparent)}.phone-widget__close-btn svg{width:.875rem;height:.875rem}.phone-widget__device-picker-wrap{flex-shrink:0;position:relative;overflow:visible}.phone-widget__device-btn{border-radius:var(--radius-sm,4px);cursor:pointer;width:1.75rem;height:1.75rem;color:var(--color-text-secondary);background:0 0;border:none;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.phone-widget__device-btn:hover,.phone-widget__device-btn--open{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 8%, transparent)}.phone-widget__device-btn svg{width:1rem;height:1rem}.phone-widget__device-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md,8px);z-index:1000;overscroll-behavior:contain;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;width:min(21rem,100vw - 2rem);max-width:calc(100vw - 2rem);max-height:min(24rem,100vh - 5rem);animation:.12s ease-out device-menu-in;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden auto;box-shadow:0 8px 24px #00000024,0 2px 6px #00000014}.phone-widget__device-menu::-webkit-scrollbar{width:6px}.phone-widget__device-menu::-webkit-scrollbar-track{background:0 0}.phone-widget__device-menu::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--color-border) 88%, transparent);border-radius:999px}@keyframes device-menu-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.phone-widget__device-menu-label{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);align-items:center;margin-bottom:.25rem;padding:.5rem .875rem .375rem;font-size:.6875rem;font-weight:600;display:flex}.phone-widget__device-menu-label--divider{border-top:1px solid var(--color-border);margin-top:.25rem;padding-top:.625rem}.phone-widget__device-option{text-align:left;cursor:pointer;width:100%;color:var(--color-text);background:0 0;border:none;align-items:center;gap:.5rem;min-width:0;padding:.4375rem .75rem;font-size:.75rem;transition:background .12s;display:flex}.phone-widget__device-option:last-child{margin-bottom:.25rem}.phone-widget__device-option:hover{background:color-mix(in srgb, var(--color-primary) 6%, transparent)}.phone-widget__device-option-check{width:1rem;height:1rem;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.phone-widget__device-option-check svg{width:.875rem;height:.875rem}.phone-widget__device-option-label{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;line-height:1.2;overflow:hidden}.phone-widget__device-option--selected .phone-widget__device-option-label{color:var(--color-primary);font-weight:600}.phone-widget__banner{flex-shrink:0;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.8125rem;line-height:1.35;display:flex}.phone-widget__banner--error{color:#b91c1c;background:#fef2f2;border-bottom:1px solid #fecaca}.phone-widget__banner--info{color:#92400e;background:#fffbeb;border-bottom:1px solid #fde68a}.phone-widget__banner-msg{flex:1;min-width:0}.phone-widget__reconnect-btn{color:inherit;border-radius:var(--radius-sm,4px);cursor:pointer;white-space:nowrap;background:0 0;border:1px solid;flex-shrink:0;padding:.15rem .5rem;font-size:.75rem;font-weight:600;transition:opacity .15s}.phone-widget__reconnect-btn:hover{opacity:.75}.phone-widget__tab-notify-badge{color:#fff;border:1.5px solid var(--color-surface);pointer-events:none;background:#ef4444;border-radius:9999px;justify-content:center;align-items:center;min-width:.9rem;height:.9rem;padding:0 .15rem;font-size:.5rem;font-weight:700;display:flex;position:absolute;top:calc(50% - 1.5rem);right:.2rem}.phone-widget__incoming{background:linear-gradient(160deg, color-mix(in srgb, #16a34a 6%, var(--color-surface)) 0%, var(--color-surface) 55%);flex-direction:column;flex:1;align-items:center;gap:.375rem;padding:2rem 1.25rem 2.25rem;display:flex}.phone-widget__incoming-badge{color:#15803d;letter-spacing:.05em;text-transform:uppercase;background:#16a34a1f;border:1px solid #16a34a4d;border-radius:9999px;align-items:center;gap:.375rem;margin-bottom:.75rem;padding:.25rem .75rem;font-size:.6875rem;font-weight:600;display:inline-flex}.phone-widget__incoming-badge-dot{background:#22c55e;border-radius:50%;flex-shrink:0;width:.4375rem;height:.4375rem;animation:.9s ease-in-out infinite dot-pulse}.phone-widget__incoming-avatar{background:color-mix(in srgb, var(--color-primary) 12%, transparent);width:5rem;height:5rem;color:var(--color-primary);box-shadow:0 0 0 0 color-mix(in srgb, var(--color-primary) 35%, transparent);border-radius:50%;justify-content:center;align-items:center;margin-bottom:.625rem;animation:1.6s ease-in-out infinite incoming-pulse;display:flex}@keyframes incoming-pulse{0%{box-shadow:0 0 0 0 color-mix(in srgb, var(--color-primary) 35%, transparent)}70%{box-shadow:0 0 0 18px #0000}to{box-shadow:0 0 #0000}}.phone-widget__incoming-avatar svg{width:2.5rem;height:2.5rem}.phone-widget__incoming-label{color:var(--color-text);text-align:center;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.015em;max-width:100%;margin:0;font-size:1.125rem;font-weight:700;overflow:hidden}.phone-widget__incoming-sublabel{color:var(--color-text-secondary);margin:0 0 1.25rem;font-size:.8125rem}.phone-widget__incoming-actions{gap:3.5rem;margin-top:.25rem;display:flex}.phone-widget__btn{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:3.75rem;height:3.75rem;transition:transform .12s,filter .12s,box-shadow .12s;display:flex}.phone-widget__btn:hover{filter:brightness(1.06);transform:scale(1.09)}.phone-widget__btn:active{transform:scale(.93)}.phone-widget__btn svg{width:1.5rem;height:1.5rem}.phone-widget__btn--answer{color:#fff;background:#16a34a;box-shadow:0 4px 16px #16a34a80}.phone-widget__btn--reject{color:#fff;background:#dc2626;box-shadow:0 4px 16px #dc262680}.phone-widget__call-strip{letter-spacing:.05em;text-transform:uppercase;flex-shrink:0;justify-content:center;align-items:center;gap:.375rem;width:100%;padding:.4375rem 1rem;font-size:.6875rem;font-weight:600;display:flex}.phone-widget__call-strip--active{background:color-mix(in srgb, #16a34a 8%, var(--color-surface));color:#15803d;border-bottom:1px solid #16a34a2e}.phone-widget__call-strip--held{background:color-mix(in srgb, #f59e0b 8%, var(--color-surface));color:#92400e;border-bottom:1px solid #f59e0b2e}.phone-widget__call-strip--dialing{background:color-mix(in srgb, var(--color-primary) 7%, var(--color-surface));color:var(--color-primary);border-bottom:1px solid color-mix(in srgb, var(--color-primary) 15%, transparent)}.phone-widget__call-strip-dot{border-radius:50%;flex-shrink:0;width:.4375rem;height:.4375rem}.phone-widget__call-strip--active .phone-widget__call-strip-dot{background:#22c55e;animation:1.2s ease-in-out infinite dot-pulse}.phone-widget__call-strip--held .phone-widget__call-strip-dot{background:#f59e0b}.phone-widget__call-strip--dialing .phone-widget__call-strip-dot{background:var(--color-primary);animation:.8s ease-in-out infinite dot-pulse}.phone-widget__active{flex-direction:column;align-items:center;padding:0 0 1rem;display:flex}.phone-widget__active-label{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.015em;text-align:center;max-width:90%;margin:.875rem 0 .1875rem;font-size:1.0625rem;font-weight:700;overflow:hidden}.phone-widget__active-timer{color:var(--color-text);font-variant-numeric:tabular-nums;letter-spacing:.04em;margin:.25rem 0 1rem;font-size:1.75rem;font-weight:200}.phone-widget__active-timer--status{color:var(--color-text-secondary);letter-spacing:0;font-size:.9375rem;font-weight:500}.phone-widget__active-secondary{gap:2rem;margin-bottom:1.125rem;display:flex}.phone-widget__round-btn{cursor:pointer;background:0 0;border:none;flex-direction:column;align-items:center;gap:.3125rem;padding:0;font-family:inherit;display:flex}.phone-widget__round-btn-icon{background:var(--color-background);border:1.5px solid var(--color-border);width:3rem;height:3rem;color:var(--color-text-secondary);border-radius:50%;justify-content:center;align-items:center;transition:background .12s,border-color .12s,color .12s,transform .1s;display:flex}.phone-widget__round-btn:hover .phone-widget__round-btn-icon{background:color-mix(in srgb, var(--color-text) 6%, var(--color-background));color:var(--color-text);border-color:color-mix(in srgb, var(--color-text) 22%, var(--color-border))}.phone-widget__round-btn:active .phone-widget__round-btn-icon{transform:scale(.92)}.phone-widget__round-btn-icon svg{width:1.1875rem;height:1.1875rem}.phone-widget__round-btn-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;font-size:.625rem;font-weight:500}.phone-widget__round-btn--active .phone-widget__round-btn-icon{background:color-mix(in srgb, var(--color-primary) 12%, transparent);border-color:color-mix(in srgb, var(--color-primary) 35%, transparent);color:var(--color-primary)}.phone-widget__round-btn--active .phone-widget__round-btn-label{color:var(--color-primary)}.phone-widget__end-btn{color:#fff;cursor:pointer;letter-spacing:-.01em;background:#dc2626;border:none;border-radius:9999px;justify-content:center;align-items:center;gap:.5rem;width:calc(100% - 2rem);height:3rem;font-family:inherit;font-size:.9375rem;font-weight:600;transition:background .15s,box-shadow .15s,transform .1s;display:flex;box-shadow:0 4px 16px #dc262666}.phone-widget__end-btn svg{width:1.125rem;height:1.125rem}.phone-widget__end-btn:hover{background:#b91c1c;box-shadow:0 6px 22px #dc262680}.phone-widget__end-btn:active{transform:scale(.97);box-shadow:0 2px 8px #dc262659}.phone-widget__header-right{flex-shrink:0;align-items:center;gap:.125rem;display:flex}.phone-widget__dnd-btn{border-radius:var(--radius-sm,4px);cursor:pointer;width:1.75rem;height:1.75rem;color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.phone-widget__dnd-btn svg{width:1rem;height:1rem}.phone-widget__dnd-btn:hover{color:#f59e0b;background:#f59e0b1a}.phone-widget__dnd-btn--active{color:#ef4444;background:#ef44441f}.phone-widget__dnd-btn--active:hover{color:#dc2626;background:#ef444433}.phone-widget__transfer-row{flex-wrap:wrap;justify-content:center;gap:.375rem;width:100%;padding:.875rem 1rem 0;display:flex}.phone-widget__transfer-panel{background:color-mix(in srgb, var(--color-primary) 6%, var(--color-surface));border-top:1px solid var(--color-border);flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex}.phone-widget__transfer-title{color:var(--color-text-secondary);margin:0;font-size:.75rem;font-weight:600}.phone-widget__transfer-input{border:1px solid var(--color-border);border-radius:var(--radius-sm,4px);background:var(--color-background);width:100%;color:var(--color-text);box-sizing:border-box;outline:none;padding:.4rem .6rem;font-size:.875rem}.phone-widget__transfer-input:focus{border-color:var(--color-primary)}.phone-widget__transfer-actions{gap:.5rem;display:flex}.phone-widget__transfer-btn{border-radius:var(--radius-sm,4px);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;white-space:nowrap;flex:1;padding:.35rem .5rem;font-size:.75rem;font-weight:500;transition:background .15s,border-color .15s}.phone-widget__transfer-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.phone-widget__transfer-btn--confirm{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.phone-widget__transfer-btn--confirm:hover:not(:disabled){filter:brightness(1.1)}.phone-widget__transfer-btn--confirm:disabled{opacity:.5;cursor:not-allowed}.phone-widget__transfer-btn--cancel{color:var(--color-text-secondary);background:0 0}.phone-widget__transfer-btn--cancel:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.phone-widget__conference-leg{color:var(--color-text);justify-content:space-between;align-items:center;padding:.25rem 0;font-size:.8125rem;display:flex}.phone-widget__conference-leg-number{font-family:monospace}.phone-widget__conference-leg-remove{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm,4px);background:0 0;border:none;padding:.125rem .25rem;font-size:.75rem;transition:color .15s,background .15s}.phone-widget__conference-leg-remove:hover{color:#ef4444;background:#ef44441a}.phone-widget__dialpad{flex-direction:column;flex:1;gap:.625rem;padding:.875rem .875rem 1rem;display:flex}.phone-widget__number-input-row{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);align-items:center;gap:.25rem;padding:0 .4375rem 0 .875rem;transition:border-color .15s,box-shadow .15s;display:flex}.phone-widget__number-input-row:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2.5px color-mix(in srgb, var(--color-primary) 14%, transparent)}.phone-widget__number-input{color:var(--color-text);font-variant-numeric:tabular-nums;letter-spacing:.04em;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:.6875rem 0;font-family:inherit;font-size:1.0625rem;font-weight:500}.phone-widget__number-input::placeholder{color:var(--color-text-secondary);letter-spacing:0;opacity:.7;font-size:.875rem;font-weight:400}.phone-widget__clear-btn{cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:.3125rem;transition:color .15s,background .15s;display:flex}.phone-widget__clear-btn:hover{color:var(--color-text);background:color-mix(in srgb, var(--color-text) 7%, transparent)}.phone-widget__clear-btn svg{width:1rem;height:1rem}.phone-widget__keys{grid-template-columns:repeat(3,1fr);gap:.4375rem;display:grid}.phone-widget__key{border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-surface);height:3.125rem;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;justify-content:center;align-items:center;gap:.05rem;padding:0;font-family:inherit;transition:background 80ms,border-color 80ms,transform 80ms;display:flex}.phone-widget__key-digit{color:var(--color-text);font-size:1.0625rem;font-weight:600;line-height:1}.phone-widget__key-sub{letter-spacing:.14em;color:var(--color-text-secondary);text-transform:uppercase;min-height:.5rem;font-size:.4375rem;font-weight:700;line-height:1}.phone-widget__key:hover{background:color-mix(in srgb, var(--color-primary) 7%, var(--color-surface));border-color:color-mix(in srgb, var(--color-primary) 25%, var(--color-border))}.phone-widget__key:active{background:color-mix(in srgb, var(--color-primary) 15%, var(--color-surface));border-color:color-mix(in srgb, var(--color-primary) 40%, var(--color-border));transform:scale(.94)}.phone-widget__call-btn{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:9999px;justify-content:center;align-items:center;width:100%;height:3.125rem;margin-top:.125rem;font-size:1rem;transition:background .15s,box-shadow .15s,transform .1s;display:flex;box-shadow:0 3px 10px #16a34a66}.phone-widget__call-btn:hover:not(:disabled){background:#15803d;box-shadow:0 5px 16px #16a34a80}.phone-widget__call-btn:active:not(:disabled){transform:scale(.97)}.phone-widget__call-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.phone-widget__call-btn svg{width:1.375rem;height:1.375rem}.phone-widget__tabs{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;display:flex}.phone-widget__tab-btn{color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;letter-spacing:.01em;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;margin-bottom:-1px;padding:.5625rem .25rem;font-family:inherit;font-size:.6875rem;font-weight:500;transition:color .15s,border-color .15s}.phone-widget__tab-btn:hover{color:var(--color-text)}.phone-widget__tab-btn--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.phone-widget__recents{flex:1;overflow-y:auto}.phone-widget__recents-empty{text-align:center;color:var(--color-text-secondary);margin:0;padding:2rem 1rem;font-size:.8125rem}.phone-widget__recents-list{margin:0;padding:0;list-style:none}.phone-widget__recent-item{border-bottom:1px solid var(--color-border);align-items:center;gap:.625rem;padding:.625rem .875rem;display:flex}.phone-widget__recent-item:last-child{border-bottom:none}.phone-widget__recent-direction{flex-shrink:0;justify-content:center;align-items:center;width:1.25rem;height:1.25rem;display:flex}.phone-widget__recent-direction svg{width:1rem;height:1rem}.phone-widget__recent-direction--inbound svg{color:#16a34a}.phone-widget__recent-direction--outbound svg{color:var(--color-primary)}.phone-widget__recent-info{flex-direction:column;flex:1;gap:.125rem;min-width:0;display:flex}.phone-widget__recent-number{color:var(--color-text);cursor:pointer;text-align:left;white-space:nowrap;text-overflow:ellipsis;background:0 0;border:none;padding:0;font-size:.8125rem;font-weight:500;overflow:hidden}.phone-widget__recent-number:hover{color:var(--color-primary);text-decoration:underline}.phone-widget__recent-outcome{text-transform:capitalize;font-size:.6875rem}.phone-widget__recent-outcome--completed{color:var(--color-text-secondary)}.phone-widget__recent-outcome--missed{color:#dc2626;font-weight:600}.phone-widget__recent-outcome--rejected{color:var(--color-text-secondary)}.phone-widget__recent-time{color:var(--color-text-secondary);font-variant-numeric:tabular-nums;flex-shrink:0;font-size:.6875rem}.phone-widget__directory{flex-direction:column;flex:1;display:flex;overflow-y:auto}.phone-widget__directory-search-wrap{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:.625rem .875rem}.phone-widget__directory-search{border:1px solid var(--color-border);border-radius:var(--radius-sm,4px);background:var(--color-surface);width:100%;color:var(--color-text);outline:none;padding:.375rem .625rem;font-size:.8125rem}.phone-widget__directory-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-primary) 15%, transparent)}.phone-widget__directory-avatar-wrap{flex-shrink:0;width:2rem;height:2rem;position:relative}.phone-widget__directory-avatar{background:color-mix(in srgb, var(--color-primary) 12%, transparent);width:100%;height:100%;color:var(--color-primary);-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:.6875rem;font-weight:700;display:flex}.phone-widget__presence-dot{border:1.5px solid var(--color-surface);border-radius:50%;width:.55rem;height:.55rem;position:absolute;bottom:0;right:0}.phone-widget__presence-dot--available{background:#22c55e}.phone-widget__presence-dot--on-call{background:#3b82f6}.phone-widget__presence-dot--dnd{background:#ef4444}.phone-widget__presence-dot--offline{background:#9ca3af}.phone-widget__directory-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:500;overflow:hidden}.phone-widget__directory-meta{color:var(--color-text-secondary);align-items:center;gap:.375rem;font-size:.6875rem;display:flex}.phone-widget__directory-ext{background:color-mix(in srgb, var(--color-primary) 10%, transparent);color:var(--color-primary);letter-spacing:.03em;border-radius:3px;padding:.1em .4em;font-size:.625rem;font-weight:600}.phone-widget__directory-did{color:var(--color-text-secondary)}.phone-widget__directory-shared{opacity:.6;font-style:italic}.phone-widget__directory-call-btn{color:#fff;cursor:pointer;background:#16a34a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:1.875rem;height:1.875rem;transition:transform .1s,filter .1s;display:flex}.phone-widget__directory-call-btn:hover{filter:brightness(1.1);transform:scale(1.08)}.phone-widget__directory-call-btn svg{width:.875rem;height:.875rem}.phone-widget__directory-no-line{text-align:center;width:1.875rem;color:var(--color-text-secondary);opacity:.4;flex-shrink:0;font-size:.875rem}.phone-widget__tab-badge{color:#fff;vertical-align:middle;background:#ef4444;border-radius:9999px;justify-content:center;align-items:center;min-width:1rem;height:1rem;margin-left:.25rem;padding:0 .2rem;font-size:.625rem;font-weight:700;line-height:1;display:inline-flex}.phone-widget__voicemail{flex:1;padding:.25rem 0;overflow-y:auto}.phone-widget__vm-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.phone-widget__vm-item{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.375rem;padding:.625rem .875rem;display:flex}.phone-widget__vm-item--unheard{background:color-mix(in srgb, var(--color-primary) 6%, transparent);border-left:3px solid var(--color-primary)}.phone-widget__vm-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.phone-widget__vm-caller{color:var(--color-text);flex:1;min-width:0;font-size:.8125rem;font-weight:600}.phone-widget__vm-time{color:var(--color-text-secondary);font-size:.6875rem}.phone-widget__vm-duration{color:var(--color-text-secondary);white-space:nowrap;font-size:.6875rem}.phone-widget__vm-transcript{color:var(--color-text-secondary);white-space:pre-wrap;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:.75rem;font-style:italic;line-height:1.4;display:-webkit-box;overflow:hidden}.phone-widget__vm-player{width:100%;height:2rem;accent-color:var(--color-primary)}.phone-widget__sms{flex-direction:column;flex:1;display:flex;overflow:hidden}.phone-widget__sms-back{color:var(--color-primary);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:0;font-size:.8125rem}.phone-widget__sms-threads{flex-direction:column;flex:1;display:flex;overflow:hidden}.phone-widget__sms-threads-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:.5rem .875rem;display:flex}.phone-widget__sms-threads-title{color:var(--color-text);font-size:.8125rem;font-weight:600}.phone-widget__sms-new-btn{color:var(--color-primary);cursor:pointer;background:0 0;border:none;align-items:center;padding:.25rem;display:flex}.phone-widget__sms-new-btn svg{width:1rem;height:1rem}.phone-widget__sms-thread-list{flex:1;margin:0;padding:0;list-style:none;overflow-y:auto}.phone-widget__sms-thread-item{border-bottom:1px solid var(--color-border);cursor:pointer;align-items:center;gap:.625rem;padding:.625rem .875rem;transition:background .1s;display:flex}.phone-widget__sms-thread-item:hover{background:var(--color-background)}.phone-widget__sms-thread-item--unread .phone-widget__sms-thread-number{font-weight:700}.phone-widget__sms-thread-avatar{background:var(--color-primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:.6875rem;font-weight:700;display:flex}.phone-widget__sms-thread-info{flex:1;min-width:0}.phone-widget__sms-thread-number{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;overflow:hidden}.phone-widget__sms-thread-preview{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;margin-top:.125rem;font-size:.6875rem;overflow:hidden}.phone-widget__sms-you{color:var(--color-text-secondary)}.phone-widget__sms-thread-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:.25rem;display:flex}.phone-widget__sms-thread-time{color:var(--color-text-secondary);white-space:nowrap;font-size:.625rem}.phone-widget__sms-unread-badge{background:var(--color-primary);color:#fff;border-radius:9999px;justify-content:center;align-items:center;min-width:1rem;height:1rem;padding:0 .2rem;font-size:.6rem;font-weight:700;display:inline-flex}.phone-widget__sms-conversation{flex-direction:column;flex:1;display:flex;overflow:hidden}.phone-widget__sms-convo-header{border-bottom:1px solid var(--color-border);align-items:center;gap:.625rem;padding:.5rem .875rem;display:flex}.phone-widget__sms-convo-title{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.8125rem;font-weight:600;overflow:hidden}.phone-widget__sms-messages{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent;flex-direction:column;flex:1;gap:.4375rem;padding:.75rem;display:flex;overflow-y:auto}.phone-widget__sms-bubble{flex-direction:column;max-width:80%;display:flex}.phone-widget__sms-bubble--inbound{align-self:flex-start}.phone-widget__sms-bubble--outbound{align-self:flex-end}.phone-widget__sms-bubble-body{word-break:break-word;border-radius:1.0625rem;padding:.5625rem .75rem;font-size:.8125rem;line-height:1.5}.phone-widget__sms-bubble--inbound .phone-widget__sms-bubble-body{background:color-mix(in srgb, var(--color-text) 7%, var(--color-surface));border:1px solid var(--color-border);color:var(--color-text);border-bottom-left-radius:.25rem}.phone-widget__sms-bubble--outbound .phone-widget__sms-bubble-body{background:var(--color-primary);color:#fff;border-bottom-right-radius:.25rem}.phone-widget__sms-bubble-time{color:var(--color-text-secondary);margin-top:.125rem;padding:0 .25rem;font-size:.6rem}.phone-widget__sms-bubble--outbound .phone-widget__sms-bubble-time{text-align:right}.phone-widget__sms-reply{border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;align-items:flex-end;gap:.375rem;padding:.5rem .625rem;display:flex}.phone-widget__sms-input{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text);resize:none;flex:1;max-height:6rem;padding:.5rem .625rem;font-family:inherit;font-size:.8125rem;line-height:1.45;transition:border-color .15s,box-shadow .15s}.phone-widget__sms-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb, var(--color-primary) 15%, transparent);outline:none}.phone-widget__sms-send-btn{background:var(--color-primary);color:#fff;cursor:pointer;width:2.25rem;height:2.25rem;box-shadow:0 2px 8px color-mix(in srgb, var(--color-primary) 35%, transparent);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s,transform .12s,box-shadow .12s;display:flex}.phone-widget__sms-send-btn svg{width:.9375rem;height:.9375rem}.phone-widget__sms-send-btn:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.phone-widget__sms-send-btn:not(:disabled):hover{opacity:.88;transform:scale(1.07)}.phone-widget__sms-send-btn:not(:disabled):active{transform:scale(.93)}.phone-widget__sms-compose{flex-direction:column;flex:1;gap:.5rem;padding:.625rem .625rem .5rem;display:flex;overflow-y:auto}.phone-widget__sms-compose-header{border-bottom:1px solid var(--color-border);align-items:center;gap:.625rem;padding-bottom:.375rem;display:flex}.phone-widget__sms-compose-title{color:var(--color-text);font-size:.8125rem;font-weight:600}.phone-widget__sms-to{border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text);border-radius:.375rem;width:100%;padding:.375rem .5rem;font-size:.8125rem}.phone-widget__sms-to:focus{border-color:var(--color-primary);outline:none}.phone-widget__sms-template-select{border:1px solid var(--color-border);background:var(--color-background);width:100%;color:var(--color-text-secondary);border-radius:.375rem;padding:.3rem .5rem;font-size:.75rem}.phone-widget__sms-compose .phone-widget__sms-input{min-height:4rem}.phone-widget__sms-compose .phone-widget__sms-send-btn{align-self:flex-end}.phone-widget__client-match{color:var(--color-primary);background:color-mix(in srgb, var(--color-primary) 10%, transparent);border:1px solid color-mix(in srgb, var(--color-primary) 30%, transparent);border-radius:9999px;align-items:center;gap:.3rem;margin:.25rem 0 .125rem;padding:.15rem .6rem;font-size:.75rem;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.phone-widget__client-match:hover{background:color-mix(in srgb, var(--color-primary) 18%, transparent)}.phone-widget__client-match svg{flex-shrink:0;width:.75rem;height:.75rem}.phone-widget__vm-delete{color:var(--color-text-secondary);cursor:pointer;opacity:.5;background:0 0;border:none;border-radius:.25rem;flex-shrink:0;margin-left:auto;padding:.1rem .25rem;font-size:.7rem;transition:color .15s,opacity .15s}.phone-widget__vm-item:hover .phone-widget__vm-delete{opacity:1}.phone-widget__vm-delete:hover{color:#ef4444}.phone-widget__disposition-overlay{z-index:9100;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.phone-widget__disposition-modal{background:var(--color-surface);border-radius:.625rem;flex-direction:column;gap:.625rem;width:100%;max-width:20rem;padding:1.25rem;display:flex;box-shadow:0 8px 32px #00000038}.phone-widget__disposition-title{color:var(--color-text);margin:0;font-size:.9375rem;font-weight:600}.phone-widget__disposition-caller{color:var(--color-text-secondary);margin:0;font-size:.8125rem}.phone-widget__disposition-label{color:var(--color-text);font-size:.75rem;font-weight:500}.phone-widget__disposition-select{border:1px solid var(--color-border);background:var(--color-background);width:100%;color:var(--color-text);border-radius:.375rem;padding:.4rem .5rem;font-size:.875rem}.phone-widget__disposition-select:focus{border-color:var(--color-primary);outline:none}.phone-widget__disposition-textarea{border:1px solid var(--color-border);background:var(--color-background);width:100%;color:var(--color-text);resize:none;box-sizing:border-box;border-radius:.375rem;padding:.4rem .5rem;font-family:inherit;font-size:.8125rem}.phone-widget__disposition-textarea:focus{border-color:var(--color-primary);outline:none}.phone-widget__disposition-actions{justify-content:flex-end;gap:.5rem;margin-top:.25rem;display:flex}.phone-widget__disposition-skip{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;background:0 0;border-radius:.375rem;padding:.4rem .875rem;font-size:.8125rem}.phone-widget__disposition-save{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:.375rem;padding:.4rem 1rem;font-size:.8125rem;font-weight:600;transition:opacity .15s}.phone-widget__disposition-save:disabled{opacity:.6;cursor:not-allowed}.phone-widget__disposition-save:not(:disabled):hover{opacity:.9}.layout{background:var(--color-background);width:100%;min-height:100vh}.layout__main{margin-top:0;margin-left:var(--sidebar-width);width:calc(100% - var(--sidebar-width) - 3rem);padding:1.75rem;padding-top:calc(var(--header-height) + 1.75rem);transition:margin-left var(--transition-base), margin-right .25s cubic-bezier(.4, 0, .2, 1), width var(--transition-base);box-sizing:border-box;margin-right:3rem}.layout__main--expanded{margin-left:var(--sidebar-collapsed-width);width:calc(100% - var(--sidebar-collapsed-width) - 3rem)}.layout__main--no-phone{width:calc(100% - var(--sidebar-width));margin-right:0}.layout__main--no-phone.layout__main--expanded{width:calc(100% - var(--sidebar-collapsed-width))}body.phone-sidebar-open .layout__main{width:calc(100% - var(--sidebar-width) - 22rem);margin-right:22rem}body.phone-sidebar-open .layout__main--expanded{width:calc(100% - var(--sidebar-collapsed-width) - 22rem)}.layout__backdrop{display:none}@media (width<=767px){.layout__main,.layout__main--expanded,body.phone-sidebar-open .layout__main,body.phone-sidebar-open .layout__main--expanded{width:100%;padding:1rem;padding-top:calc(var(--header-height) + 1rem);margin-left:0;margin-right:0}.layout__backdrop{-webkit-backdrop-filter:blur(3px);z-index:250;background:#0f0f148c;animation:.25s cubic-bezier(.4,0,.2,1) forwards backdropIn;display:block;position:fixed;inset:0}}@keyframes backdropIn{0%{opacity:0;-webkit-backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(3px)}}.layout__page-transition{width:100%;animation:.18s forwards page-fade-in}@keyframes page-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
