:root{--color-primary: #1a4d2e;--color-primary-light: #2d6b42;--color-primary-dark: #0f2d1a;--color-accent: #7c5c3a;--color-accent-light: #9b7a55;--color-text: #1a1a18;--color-text-muted: #6b6b67;--color-bg: #f5f2ee;--color-surface: #ffffff;--color-border: #e8e2d9;--color-success: #2d6b42;--color-warning: #c17f24;--color-danger: #b03a2e;--color-info: #1e5799;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-7: 1.75rem;--space-8: 2rem;--space-9: 2.25rem;--space-10: 2.5rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Fira Code", "Fira Mono", "Roboto Mono", monospace;--font-size-xs: .6875rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-base: 1.5;--line-height-relaxed: 1.625;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-2xl: 24px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .06);--shadow-sm: 0 1px 4px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .06);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .16);--transition-fast: .1s ease;--transition-base: .15s ease;--transition-slow: .25s ease;--z-base: 0;--z-raised: 10;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-toast: 400;--z-tooltip: 500;--sidebar-width: 240px;--header-height: 56px;--bottom-nav-height: 60px;--content-max-width: 1200px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-lg)}h4{font-size:var(--font-size-md)}p{line-height:var(--line-height-base)}ul,ol{list-style:none}#root{min-height:100vh;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:.625rem 1.25rem;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border-radius:var(--radius-md);border:1.5px solid transparent;transition:background var(--transition-base),color var(--transition-base),border-color var(--transition-base),box-shadow var(--transition-base);white-space:nowrap;-webkit-user-select:none;user-select:none;text-decoration:none;line-height:1}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn--primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn--primary:hover{background:var(--color-primary-light);border-color:var(--color-primary-light);box-shadow:0 2px 8px #1a4d2e4d}.btn--primary:active{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.btn--secondary{background:var(--color-surface);color:var(--color-primary);border-color:var(--color-border)}.btn--secondary:hover{background:var(--color-bg);border-color:var(--color-primary)}.btn--secondary:active{background:#ece8e2}.btn--danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn--danger:hover{background:#c94134;border-color:#c94134;box-shadow:0 2px 8px #b03a2e4d}.btn--ghost{background:transparent;color:var(--color-primary);border-color:transparent}.btn--ghost:hover{background:#1a4d2e14}.btn--warning{background:var(--color-warning);color:#fff;border-color:var(--color-warning)}.btn--warning:hover{background:#d48c2a}.btn--sm{padding:.375rem .875rem;font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn--md{padding:.625rem 1.25rem;font-size:var(--font-size-base)}.btn--lg{padding:.875rem 1.75rem;font-size:var(--font-size-md)}.btn--full{width:100%}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.label--required:after{content:" *";color:var(--color-danger)}.input,.select,.textarea{width:100%;padding:.625rem .875rem;font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-base),box-shadow var(--transition-base);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1a4d2e1f}.input::placeholder,.textarea::placeholder{color:var(--color-text-muted)}.input--error,.select--error,.textarea--error{border-color:var(--color-danger)}.input--error:focus,.select--error:focus,.textarea--error:focus{box-shadow:0 0 0 3px #b03a2e1f}.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b6b67' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .875rem center;padding-right:2.5rem;cursor:pointer}.textarea{resize:vertical;min-height:5rem;line-height:var(--line-height-relaxed)}.field-error{font-size:var(--font-size-sm);color:var(--color-danger)}.field-helper{font-size:var(--font-size-sm);color:var(--color-text-muted)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card__header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.card__title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text)}.card__body{padding:var(--space-5)}.card__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border);background:var(--color-bg)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:.1875rem .5rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);border-radius:var(--radius-full);white-space:nowrap}.badge--success{background:#2d6b421f;color:var(--color-success)}.badge--warning{background:#c17f241f;color:var(--color-warning)}.badge--danger{background:#b03a2e1f;color:var(--color-danger)}.badge--info{background:#1e57991f;color:var(--color-info)}.badge--neutral{background:#6b6b671f;color:var(--color-text-muted)}.badge--primary{background:#1a4d2e1f;color:var(--color-primary)}.spinner{display:inline-block;border-style:solid;border-color:currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}.spinner--sm{width:14px;height:14px;border-width:2px}.spinner--md{width:24px;height:24px;border-width:2.5px}.spinner--lg{width:40px;height:40px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fadeIn .15s ease}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .2s ease}.modal__header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-shrink:0}.modal__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.modal__close{background:none;border:none;padding:var(--space-1);border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:1.25rem;line-height:1;transition:color var(--transition-fast),background var(--transition-fast)}.modal__close:hover{color:var(--color-text);background:var(--color-bg)}.modal__body{padding:var(--space-6);overflow-y:auto;flex:1}.modal__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;font-weight:var(--font-weight-bold);background:var(--color-primary);color:#fff;-webkit-user-select:none;user-select:none}.avatar--sm{width:28px;height:28px;font-size:var(--font-size-xs)}.avatar--md{width:36px;height:36px;font-size:var(--font-size-sm)}.avatar--lg{width:48px;height:48px;font-size:var(--font-size-md)}.avatar--xl{width:72px;height:72px;font-size:var(--font-size-xl)}.avatar img{width:100%;height:100%;object-fit:cover}.toast-container{position:fixed;bottom:max(var(--space-6),env(safe-area-inset-bottom,var(--space-6)));right:var(--space-4);z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--space-2);max-width:380px;width:calc(100vw - var(--space-8))}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:toastIn .2s ease;border-left:4px solid transparent;background:var(--color-surface);min-width:0}.toast__icon{font-size:1rem;flex-shrink:0;margin-top:1px}.toast__content{flex:1;min-width:0}.toast__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);line-height:1.4}.toast__message{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px;line-height:1.4}.toast__close{background:none;border:none;color:var(--color-text-muted);font-size:1rem;padding:0;flex-shrink:0;line-height:1}.toast__close:hover{color:var(--color-text)}.toast--success{border-left-color:var(--color-success)}.toast--error{border-left-color:var(--color-danger)}.toast--warning{border-left-color:var(--color-warning)}.toast--info{border-left-color:var(--color-info)}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-10) var(--space-6);gap:var(--space-3)}.empty-state__icon{font-size:3rem;opacity:.6;line-height:1}.empty-state__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text)}.empty-state__description{font-size:var(--font-size-base);color:var(--color-text-muted);max-width:300px;line-height:var(--line-height-relaxed)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-2);border-top:3px solid var(--card-accent, var(--color-primary));box-shadow:var(--shadow-sm)}.stat-card--clickable{cursor:pointer;transition:box-shadow var(--transition-base),transform var(--transition-base)}.stat-card--clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.stat-card__icon{font-size:1.5rem}.stat-card__value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);line-height:1}.stat-card__label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.sync-indicator{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-xs);color:var(--color-text-muted)}.sync-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.sync-dot--online{background:var(--color-success);box-shadow:0 0 0 2px #2d6b4233}.sync-dot--offline{background:var(--color-warning);box-shadow:0 0 0 2px #c17f2433}.sync-spinner{width:8px;height:8px;border:1.5px solid var(--color-info);border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.sync-label{font-size:var(--font-size-xs);color:var(--color-text-muted)}.app-shell{display:flex;min-height:100vh}.app-shell__sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--color-primary-dark);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:var(--z-sticky);overflow-y:auto}.app-shell__main{flex:1;display:flex;flex-direction:column;min-height:100vh}.app-shell__content{flex:1;overflow-y:auto}.header{height:var(--header-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-3);padding:0 var(--space-4);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-xs)}.header__brand{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-bold);font-size:var(--font-size-md);color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em;text-decoration:none}.header__brand:hover{text-decoration:none}.header__brand-icon{width:28px;height:28px;background:var(--color-primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.header__spacer{flex:1}.header__actions{display:flex;align-items:center;gap:var(--space-2)}.header__icon-btn{background:none;border:none;padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:1.125rem;line-height:1;transition:background var(--transition-fast),color var(--transition-fast);position:relative}.header__icon-btn:hover{background:var(--color-bg);color:var(--color-text)}.header__notif-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;background:var(--color-danger);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px}.sidebar{display:flex;flex-direction:column;height:100%;padding:var(--space-4) 0}.sidebar__brand{padding:var(--space-2) var(--space-5) var(--space-6);display:flex;align-items:center;gap:var(--space-3);color:#fff;font-weight:var(--font-weight-bold);font-size:var(--font-size-md);text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:var(--space-4)}.sidebar__brand-icon{width:32px;height:32px;background:#ffffff26;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:900}.sidebar__nav{flex:1;padding:0 var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-md);color:#ffffffb3;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast),color var(--transition-fast);text-decoration:none;position:relative}.sidebar__nav-item:hover{background:#ffffff14;color:#fff;text-decoration:none}.sidebar__nav-item.active{background:#ffffff26;color:#fff}.sidebar__nav-icon{font-size:1rem;flex-shrink:0;width:20px;text-align:center}.sidebar__nav-badge{margin-left:auto;min-width:18px;height:18px;background:var(--color-danger);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 4px}.sidebar__section-label{padding:var(--space-3) var(--space-3) var(--space-1);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.1em;color:#ffffff59}.sidebar__footer{padding:var(--space-4) var(--space-3);border-top:1px solid rgba(255,255,255,.1);margin-top:auto}.bottom-nav{height:var(--bottom-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border);display:flex;align-items:stretch;position:fixed;bottom:0;left:0;right:0;z-index:var(--z-sticky);padding-bottom:env(safe-area-inset-bottom,0);box-shadow:0 -2px 8px #0000000f}.bottom-nav__item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;color:var(--color-text-muted);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-fast);position:relative;padding:var(--space-2)}.bottom-nav__item:hover{text-decoration:none}.bottom-nav__item.active{color:var(--color-primary)}.bottom-nav__icon{font-size:1.25rem;line-height:1}.bottom-nav__badge{position:absolute;top:var(--space-1);left:50%;transform:translate(4px);min-width:16px;height:16px;background:var(--color-danger);color:#fff;border-radius:var(--radius-full);font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px}.page{padding:var(--space-5);max-width:900px;margin:0 auto;width:100%}.page--wide{max-width:var(--content-max-width)}.page__header{margin-bottom:var(--space-6)}.page__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.page__subtitle{font-size:var(--font-size-base);color:var(--color-text-muted);margin-top:var(--space-1)}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-5);background:var(--color-bg)}.auth-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:var(--space-8);width:100%;max-width:420px}.auth-logo{text-align:center;margin-bottom:var(--space-7)}.auth-logo__icon{width:52px;height:52px;background:var(--color-primary);border-radius:var(--radius-lg);display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:900;color:#fff;margin:0 auto var(--space-3)}.auth-logo__name{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary);text-transform:uppercase;letter-spacing:.1em}.auth-logo__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.auth-form{display:flex;flex-direction:column;gap:var(--space-4)}.auth-form__footer{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-2)}.conversation-list{display:flex;flex-direction:column;background:var(--color-surface)}.conversation-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--transition-fast);text-decoration:none;color:inherit}.conversation-item:hover{background:var(--color-bg);text-decoration:none}.conversation-item__content{flex:1;min-width:0}.conversation-item__name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-item__preview{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}.conversation-item__meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0}.conversation-item__time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.conversation-item--unread .conversation-item__name{font-weight:var(--font-weight-bold)}.message-list{flex:1;overflow-y:auto;padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-3)}.message-date-divider{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-muted);padding:var(--space-2) 0;position:relative}.message-date-divider:before,.message-date-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 60px);height:1px;background:var(--color-border)}.message-date-divider:before{left:0}.message-date-divider:after{right:0}.message-bubble-wrapper{display:flex;gap:var(--space-2)}.message-bubble-wrapper--own{flex-direction:row-reverse}.message-bubble{max-width:75%;display:flex;flex-direction:column;gap:3px}.message-bubble__sender{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:0 var(--space-2)}.message-bubble__content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);border-bottom-left-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-text);word-break:break-word}.message-bubble-wrapper--own .message-bubble__content{background:var(--color-primary);color:#fff;border-color:var(--color-primary);border-bottom-left-radius:var(--radius-lg);border-bottom-right-radius:var(--radius-sm)}.message-bubble__meta{font-size:var(--font-size-xs);color:var(--color-text-muted);padding:0 var(--space-2);display:flex;align-items:center;gap:var(--space-1)}.message-bubble-wrapper--own .message-bubble__meta{justify-content:flex-end}.message-bubble__attachments{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.message-attachment-thumb{width:120px;height:90px;object-fit:cover;border-radius:var(--radius-md);cursor:pointer}.send-bar{background:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--space-3) var(--space-4);padding-bottom:max(var(--space-3),env(safe-area-inset-bottom,var(--space-3)));display:flex;align-items:flex-end;gap:var(--space-2)}.send-bar__textarea{flex:1;resize:none;border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);font-family:inherit;background:var(--color-bg);color:var(--color-text);max-height:120px;overflow-y:auto;outline:none;line-height:var(--line-height-relaxed)}.send-bar__textarea:focus{border-color:var(--color-primary)}.send-bar__btn{background:none;border:none;padding:var(--space-2);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:1.25rem;transition:color var(--transition-fast),background var(--transition-fast);flex-shrink:0}.send-bar__btn:hover{color:var(--color-primary);background:#1a4d2e14}.send-bar__send-btn{background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-full);width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background var(--transition-base);flex-shrink:0}.send-bar__send-btn:hover{background:var(--color-primary-light)}.send-bar__send-btn:disabled{opacity:.5}.send-bar__previews{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-bottom:var(--space-2)}.send-bar__preview-item{position:relative}.send-bar__preview-img{width:60px;height:60px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border)}.send-bar__preview-remove{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--color-danger);color:#fff;border:none;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;cursor:pointer}.photo-capture{display:flex;flex-direction:column;gap:var(--space-3)}.photo-previews{display:flex;flex-wrap:wrap;gap:var(--space-2)}.photo-preview-thumb{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-md);border:2px solid var(--color-border)}.checklist-field{display:flex;flex-direction:column;gap:var(--space-2)}.radio-group{display:flex;gap:var(--space-3)}.radio-option{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-base)}.radio-option input[type=radio]{accent-color:var(--color-primary);width:16px;height:16px}.checkbox-option{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-base)}.checkbox-option input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px}.notification-item{display:flex;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border);transition:background var(--transition-fast);cursor:pointer}.notification-item:hover{background:var(--color-bg)}.notification-item--unread{background:#1a4d2e0a}.notification-item__icon{font-size:1.25rem;flex-shrink:0}.notification-item__content{flex:1;min-width:0}.notification-item__title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base);color:var(--color-text)}.notification-item__body{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:2px;line-height:var(--line-height-relaxed)}.notification-item__time{font-size:var(--font-size-xs);color:var(--color-text-muted);flex-shrink:0;margin-top:2px}.activity-feed{display:flex;flex-direction:column;gap:0}.activity-item{display:flex;gap:var(--space-3);padding:var(--space-3) 0;border-bottom:1px solid var(--color-border)}.activity-item:last-child{border-bottom:none}.activity-item__icon{font-size:1rem;width:28px;height:28px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-item__content{flex:1;min-width:0}.activity-item__text{font-size:var(--font-size-sm);color:var(--color-text);line-height:var(--line-height-relaxed)}.activity-item__time{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table th{background:var(--color-bg);padding:var(--space-3) var(--space-4);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#00000005}.tabs{display:flex;border-bottom:2px solid var(--color-border);gap:0;overflow-x:auto}.tab-btn{padding:var(--space-3) var(--space-5);background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;transition:color var(--transition-fast),border-color var(--transition-fast)}.tab-btn:hover{color:var(--color-text)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.steps{display:flex;align-items:center;gap:0;margin-bottom:var(--space-6);overflow-x:auto}.step{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.step__dot{width:28px;height:28px;border-radius:50%;background:var(--color-border);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-muted);flex-shrink:0}.step--active .step__dot{background:var(--color-primary);color:#fff}.step--done .step__dot{background:var(--color-success);color:#fff}.step__label{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.step--active .step__label{color:var(--color-primary);font-weight:var(--font-weight-semibold)}.step--done .step__label{color:var(--color-success)}.step__connector{flex:1;min-width:var(--space-4);height:1px;background:var(--color-border);margin:0 var(--space-2)}.step--done+.step .step__connector,.step--done .step__connector{background:var(--color-success)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-4);margin-bottom:var(--space-6)}.dashboard-grid{display:grid;gap:var(--space-5)}@media (min-width: 600px){.dashboard-grid{grid-template-columns:1fr 1fr}}@media (min-width: 900px){.dashboard-grid{grid-template-columns:1fr 1fr 1fr}}.queue-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}.queue-item__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.queue-item__name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.queue-item__meta{display:flex;flex-wrap:wrap;gap:var(--space-3);font-size:var(--font-size-sm);color:var(--color-text-muted)}.queue-item__actions{display:flex;gap:var(--space-2);flex-wrap:wrap;padding-top:var(--space-3);border-top:1px solid var(--color-border)}.template-field-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.template-field-row__drag{color:var(--color-text-muted);cursor:grab;font-size:1rem}.template-field-row__content{flex:1;min-width:0;display:grid;grid-template-columns:1fr auto auto;gap:var(--space-3);align-items:center}.loading-overlay{display:flex;align-items:center;justify-content:center;padding:var(--space-10)}.error-message{background:#b03a2e14;color:var(--color-danger);border:1px solid rgba(176,58,46,.2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--space-2)}.success-message{background:#2d6b4214;color:var(--color-success);border:1px solid rgba(45,107,66,.2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);display:flex;align-items:center;gap:var(--space-2)}.info-box{background:#1e57990f;color:var(--color-info);border:1px solid rgba(30,87,153,.2);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}@media (max-width: 767px){.hide-mobile{display:none!important}.app-shell__sidebar{display:none}.app-shell__main{padding-bottom:var(--bottom-nav-height)}.page{padding:var(--space-4)}.auth-card{padding:var(--space-6) var(--space-5)}}@media (min-width: 768px){.hide-desktop{display:none!important}.bottom-nav{display:none}.app-shell__main{margin-left:var(--sidebar-width)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.inline-flex{display:inline-flex}.block{display:block}.hidden{display:none!important}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.shrink-0{flex-shrink:0}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-primary{color:var(--color-primary)}.text-sm{font-size:var(--font-size-sm)}.text-xs{font-size:var(--font-size-xs)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-center{text-align:center}.text-right{text-align:right}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.w-full{width:100%}.h-full{height:100%}.min-w-0{min-width:0}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.border{border:1px solid var(--color-border)}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.bg-surface{background:var(--color-surface)}.bg-bg{background:var(--color-bg)}.cursor-pointer{cursor:pointer}.leading-relaxed{line-height:var(--line-height-relaxed)}.leading-tight{line-height:var(--line-height-tight)}.relative{position:relative}.absolute{position:absolute}.sticky{position:sticky}
