@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable-dynamic-subset.min.css";:root{--primary-50: #eff6ff;--primary-100: #dbeafe;--primary-200: #bfdbfe;--primary-300: #93c5fd;--primary-400: #60a5fa;--primary-500: #3b82f6;--primary-600: #2563eb;--primary-700: #1d4ed8;--primary-800: #1e40af;--primary-900: #1e3a8a;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--success: #22c55e;--success-bg: #f0fdf4;--warning: #f59e0b;--warning-bg: #fffbeb;--danger: #ef4444;--danger-bg: #fef2f2;--info: #3b82f6;--info-bg: #eff6ff;--sidebar-bg: #0f172a;--sidebar-hover: #1e293b;--sidebar-active: #1e3a8a;--sidebar-text: #94a3b8;--sidebar-text-active: #ffffff;--sidebar-width: 250px;--sidebar-collapsed-width: 68px;--topbar-height: 60px;--topbar-bg: #ffffff;--topbar-shadow: 0 1px 3px rgba(0, 0, 0, .05), 0 1px 2px rgba(0, 0, 0, .03);--content-bg: #f1f5f9;--card-bg: #ffffff;--card-shadow: 0 1px 3px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .02);--card-shadow-hover: 0 8px 25px rgba(0, 0, 0, .08);--card-radius: 12px;--font-family: "Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .35s ease;--z-sidebar: 100;--z-topbar: 90;--z-modal: 200;--z-tooltip: 300}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--gray-800);background:var(--content-bg);line-height:1.6;overflow-x:hidden}a{color:var(--primary-600);text-decoration:none}a:hover{color:var(--primary-700)}img{max-width:100%;display:block}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);position:fixed;top:0;left:0;bottom:0;z-index:var(--z-sidebar);display:flex;flex-direction:column;transition:width var(--transition-base);overflow:hidden}.sidebar-logo{height:var(--topbar-height);display:flex;align-items:center;padding:0 var(--spacing-lg);border-bottom:1px solid rgba(255,255,255,.06);gap:var(--spacing-sm)}.sidebar-logo h1{color:#fff;font-size:var(--font-size-lg);font-weight:700;white-space:nowrap}.sidebar-logo .logo-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0;letter-spacing:-.02em}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.sidebar-section-label{padding:var(--spacing-md) var(--spacing-lg) var(--spacing-xs);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em;color:#a3a8c380;font-weight:600;white-space:nowrap}.sidebar-link{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px var(--spacing-lg);color:var(--sidebar-text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;background:none;width:100%;text-align:left}.sidebar-link:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.sidebar-link.active{background:var(--sidebar-active);color:var(--sidebar-text-active)}.sidebar-link .link-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-link .link-icon svg{width:20px;height:20px}.sidebar-link .link-badge{margin-left:auto;background:var(--primary-500);color:#fff;font-size:11px;padding:2px 7px;border-radius:10px;font-weight:600}.sidebar-toggle{display:flex;align-items:center;justify-content:center;height:44px;margin:var(--spacing-sm) var(--spacing-sm) var(--spacing-md);border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#ffffff0a;color:var(--sidebar-text);cursor:pointer;transition:all var(--transition-fast)}.sidebar-toggle:hover{background:#ffffff14;color:#fff}.sidebar-toggle svg{width:18px;height:18px}.sidebar-collapsed .sidebar{width:var(--sidebar-collapsed-width)}.sidebar-collapsed .topbar{left:var(--sidebar-collapsed-width)}.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-width)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar.collapsed .sidebar-logo{justify-content:center;padding:0}.sidebar.collapsed .sidebar-section-label{display:none}.sidebar.collapsed .sidebar-link{justify-content:center;padding:10px}.sidebar.collapsed .sidebar-link .link-text,.sidebar.collapsed .sidebar-link .link-badge{display:none}.sidebar.collapsed+.topbar{left:var(--sidebar-collapsed-width)}.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed-width)}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:var(--spacing-md);color:var(--gray-500)}.app-loading-spinner{width:36px;height:36px;border:3px solid var(--gray-200);border-top-color:var(--primary-500);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.topbar{height:var(--topbar-height);background:var(--topbar-bg);box-shadow:var(--topbar-shadow);position:fixed;top:0;left:var(--sidebar-width);right:0;z-index:var(--z-topbar);display:flex;align-items:center;padding:0 var(--spacing-xl);gap:var(--spacing-md);transition:left var(--transition-base)}.topbar-search{flex:1;max-width:480px;position:relative}.topbar-search input{width:100%;height:40px;padding:0 var(--spacing-md) 0 40px;border:1px solid var(--gray-200);border-radius:10px;background:var(--gray-50);font-size:var(--font-size-sm);font-family:var(--font-family);transition:all var(--transition-fast);color:var(--gray-800)}.topbar-search input:focus{outline:none;border-color:var(--primary-300);background:#fff;box-shadow:0 0 0 3px var(--primary-50)}.topbar-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);font-size:16px}.topbar-actions{display:flex;align-items:center;gap:var(--spacing-sm);margin-left:auto}.topbar-btn{width:40px;height:40px;border:none;background:transparent;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600);font-size:18px;transition:all var(--transition-fast);position:relative}.topbar-btn.active{background:var(--primary-50);color:var(--primary-700)}.topbar-btn:hover{background:var(--gray-100);color:var(--gray-800)}.topbar-user{display:flex;align-items:center;gap:var(--spacing-sm);border:none;background:transparent;padding:4px 12px 4px 4px;border-radius:10px;cursor:pointer;transition:background var(--transition-fast)}.topbar-user:hover{background:var(--gray-100)}.topbar-user-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary-400),var(--primary-600));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-sm)}.topbar-user-info{display:flex;flex-direction:column}.topbar-user-name{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-800);line-height:1.2}.topbar-user-role{font-size:var(--font-size-xs);color:var(--gray-500);line-height:1.2}.topbar-user.active{background:var(--gray-100)}.topbar-icon{width:18px;height:18px}.topbar-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--topbar-bg)}.topbar-menu{position:relative}.topbar-caret{width:16px;height:16px;color:var(--gray-400);flex-shrink:0}.topbar-panel,.topbar-dropdown{position:absolute;top:calc(100% + 10px);right:0;border:1px solid var(--gray-200);border-radius:16px;background:#fffffffa;box-shadow:0 24px 48px #0f172a2e;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.topbar-panel{width:min(420px,calc(100vw - 32px));overflow:hidden}.topbar-panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-md) var(--spacing-md) var(--spacing-sm);border-bottom:1px solid var(--gray-100)}.topbar-panel-subtitle{margin-top:4px;font-size:var(--font-size-xs);color:var(--gray-500)}.topbar-panel-body{max-height:420px;overflow:auto}.topbar-panel-status{padding:var(--spacing-lg);text-align:center;color:var(--gray-500);font-size:var(--font-size-sm)}.topbar-panel-status.error{color:var(--danger)}.topbar-panel-empty{padding:var(--spacing-xl) var(--spacing-lg);text-align:center}.topbar-panel-empty strong{display:block;color:var(--gray-800)}.topbar-panel-empty p{margin-top:var(--spacing-xs);color:var(--gray-500);font-size:var(--font-size-sm)}.topbar-panel-list{display:grid}.topbar-panel-item{width:100%;border:none;background:transparent;display:flex;align-items:flex-start;gap:var(--spacing-sm);text-align:left;padding:var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--gray-100);transition:background var(--transition-fast)}.topbar-panel-item:last-child{border-bottom:none}.topbar-panel-item:hover{background:var(--gray-50)}.topbar-panel-item.disabled{cursor:default}.topbar-panel-item.disabled:hover{background:transparent}.topbar-panel-item.unread{background:linear-gradient(90deg,#6366f114,#6366f100)}.topbar-panel-item-main{min-width:0;flex:1}.topbar-panel-item-head{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.topbar-panel-category{color:var(--primary-700);font-size:var(--font-size-xs);font-weight:700}.topbar-panel-time{color:var(--gray-400);font-size:var(--font-size-xs);flex-shrink:0}.topbar-panel-message{margin-top:6px;color:var(--gray-700);font-size:var(--font-size-sm);line-height:1.5}.topbar-panel-dot{width:10px;height:10px;border-radius:999px;background:var(--primary-500);margin-top:6px;flex-shrink:0}.topbar-dropdown{width:200px;padding:8px;display:grid;gap:4px}.topbar-dropdown-item{width:100%;border:none;border-radius:12px;background:transparent;padding:12px 14px;text-align:left;font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.topbar-dropdown-item:hover{background:var(--gray-50);color:var(--gray-900)}.topbar-dropdown-item.danger{color:var(--danger)}.topbar-dropdown-item.danger:hover{background:#ef444414}.main-content{margin-left:var(--sidebar-width);padding-top:var(--topbar-height);flex:1;transition:margin-left var(--transition-base)}.page-content{padding:var(--spacing-lg);min-height:calc(100vh - var(--topbar-height))}.page-header{margin-bottom:var(--spacing-lg)}.page-header h2{font-size:var(--font-size-2xl);font-weight:700;color:var(--gray-900)}.page-header p{color:var(--gray-500);margin-top:var(--spacing-xs)}.page-header-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);transition:box-shadow var(--transition-base)}.card:hover{box-shadow:var(--card-shadow-hover)}.card-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.card-header h3{font-size:var(--font-size-md);font-weight:600;color:var(--gray-800)}.card-body{padding:var(--spacing-lg)}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);padding:var(--spacing-lg);display:flex;align-items:flex-start;gap:var(--spacing-md);transition:all var(--transition-base);position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px}.stat-card.blue:before{background:linear-gradient(90deg,#4c6ef5,#748ffc)}.stat-card.green:before{background:linear-gradient(90deg,#37b24d,#69db7c)}.stat-card.orange:before{background:linear-gradient(90deg,#f76707,#ffa94d)}.stat-card.purple:before{background:linear-gradient(90deg,#7950f2,#b197fc)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.stat-icon.blue{background:var(--primary-50);color:var(--primary-600)}.stat-icon.green{background:var(--success-bg);color:#37b24d}.stat-icon.orange{background:#fff4e6;color:#f76707}.stat-icon.purple{background:#f3f0ff;color:#7950f2}.stat-info h4{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);margin-bottom:var(--spacing-xs)}.stat-info .stat-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--gray-900);line-height:1}.stat-info .stat-change{font-size:var(--font-size-xs);margin-top:var(--spacing-xs);display:flex;align-items:center;gap:4px}.stat-change.up{color:#37b24d}.stat-change.down{color:var(--danger)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:10px 20px;border:none;border-radius:10px;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--primary-600),var(--primary-700));color:#fff;box-shadow:0 2px 8px #4c6ef54d}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-700),var(--primary-800));transform:translateY(-1px);box-shadow:0 4px 12px #4c6ef566}.btn-secondary{background:var(--gray-100);color:var(--gray-700)}.btn-secondary:hover{background:var(--gray-200)}.btn-outline{background:transparent;color:var(--primary-600);border:1px solid var(--primary-200)}.btn-outline:hover{background:var(--primary-50);border-color:var(--primary-300)}.btn-sm{padding:6px 14px;font-size:var(--font-size-xs)}.btn-lg{padding:14px 28px;font-size:var(--font-size-md)}.btn-icon{width:36px;height:36px;padding:0;border-radius:10px;display:inline-flex;align-items:center;justify-content:center}.btn:disabled{opacity:.65;cursor:not-allowed;transform:none;box-shadow:none}.form-group{margin-bottom:var(--spacing-md)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;color:var(--gray-700);margin-bottom:var(--spacing-xs)}.form-input,.card input:not([type=checkbox]):not([type=radio]):not([type=file]):not(.form-file-input),.card select:not(.form-input),.card textarea:not(.form-input){width:100%;height:42px;padding:0 var(--spacing-md);border:1px solid var(--gray-300);border-radius:10px;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--gray-800);transition:all var(--transition-fast);background:#fff}.form-input:focus,.card input:not([type=checkbox]):not([type=radio]):not([type=file]):not(.form-file-input):focus,.card select:not(.form-input):focus,.card textarea:not(.form-input):focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.form-input::placeholder,.card input:not([type=checkbox]):not([type=radio]):not([type=file]):not(.form-file-input)::placeholder,.card textarea:not(.form-input)::placeholder{color:var(--gray-400)}textarea.form-input,.card textarea:not(.form-input){height:auto;min-height:100px;padding:var(--spacing-md);resize:vertical}.form-shell{display:grid;gap:var(--spacing-lg)}.form-grid{display:grid;gap:var(--spacing-md);grid-template-columns:repeat(2,minmax(0,1fr))}.form-span-2{grid-column:1 / -1}.form-section{display:grid;gap:var(--spacing-md);padding:var(--spacing-lg);border:1px solid var(--gray-100);border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,var(--gray-50) 100%)}.form-section-title{font-size:var(--font-size-sm);font-weight:700;color:var(--gray-800)}.form-helper{margin-top:var(--spacing-xs);font-size:var(--font-size-xs);color:var(--gray-500);line-height:1.5}.form-static{width:100%;min-height:42px;padding:0 var(--spacing-md);border:1px solid var(--gray-200);border-radius:10px;background:var(--gray-50);color:var(--gray-700);display:flex;align-items:center}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);flex-wrap:wrap}.form-file{display:grid;gap:var(--spacing-sm)}.form-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.form-file-control{display:flex;align-items:center;gap:var(--spacing-sm);min-height:48px;padding:var(--spacing-sm);border:1px solid var(--gray-200);border-radius:12px;background:#fff;cursor:pointer}.form-file-button{display:inline-flex;align-items:center;justify-content:center;min-width:96px;padding:10px 14px;border-radius:10px;background:var(--primary-50);color:var(--primary-700);font-size:var(--font-size-sm);font-weight:600}.form-file-name{color:var(--gray-600);font-size:var(--font-size-sm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-toggle{display:inline-flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--gray-700)}.check-list{display:grid;gap:var(--spacing-sm);max-height:240px;overflow-y:auto;padding:var(--spacing-sm);border:1px solid var(--gray-200);border-radius:12px;background:#ffffffe6}.check-item{display:grid;grid-template-columns:auto 1fr;gap:var(--spacing-sm);align-items:start;padding:10px 12px;border-radius:10px;border:1px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast)}.check-item:hover{background:var(--gray-50);border-color:var(--gray-200)}.editor-surface{min-height:280px;padding:var(--spacing-md);border:1px solid var(--gray-200);border-radius:14px;background:#fff;color:var(--gray-800);line-height:1.7;overflow:auto;box-shadow:inset 0 1px 2px #0f172a0a}.editor-surface:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.data-table{width:100%;border-collapse:separate;border-spacing:0}.data-table th{padding:var(--spacing-sm) var(--spacing-md);text-align:left;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-500);background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.data-table th:first-child{border-radius:8px 0 0}.data-table th:last-child{border-radius:0 8px 0 0}.data-table td{padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--gray-100);font-size:var(--font-size-sm);color:var(--gray-700)}.data-table tr:hover td{background:var(--gray-50)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:6px;font-size:var(--font-size-xs);font-weight:600}.badge-blue{background:var(--primary-50);color:var(--primary-700)}.badge-green{background:var(--success-bg);color:#2b8a3e}.badge-orange{background:var(--warning-bg);color:#e67700}.badge-red{background:var(--danger-bg);color:#c92a2a}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.badge-purple{background:#f3f0ff;color:#6741d9}.tabs{display:flex;gap:2px;background:var(--gray-100);border-radius:10px;padding:3px;width:fit-content}.tab-btn{padding:8px 20px;border:none;background:transparent;border-radius:8px;font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:500;color:var(--gray-600);cursor:pointer;transition:all var(--transition-fast)}.tab-btn.active{background:#fff;color:var(--gray-800);box-shadow:0 1px 3px #00000014;font-weight:600}.tab-btn:hover:not(.active){color:var(--gray-700)}.list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:10px;transition:background var(--transition-fast);cursor:pointer}.list-item:hover{background:var(--gray-50)}.list-item+.list-item{border-top:1px solid var(--gray-100)}.avatar{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs);border-radius:8px}.avatar-lg{width:56px;height:56px;font-size:var(--font-size-lg);border-radius:14px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:1024px){.grid-2,.grid-3,.form-grid{grid-template-columns:1fr}.form-span-2{grid-column:auto}}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--gray-400)}.empty-state .empty-icon{font-size:48px;margin-bottom:var(--spacing-md);opacity:.5}.empty-state h3{color:var(--gray-600);margin-bottom:var(--spacing-sm)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e3a8a,#0f172a);position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,var(--primary-500) 0%,transparent 70%);opacity:.12;top:-200px;right:-200px;border-radius:50%}.login-container:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,var(--primary-400) 0%,transparent 70%);opacity:.08;bottom:-100px;left:-100px;border-radius:50%}.login-card{width:420px;background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:var(--spacing-2xl);box-shadow:0 20px 60px #0000004d;position:relative;z-index:1;animation:loginSlideUp .5s ease forwards}@keyframes loginSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card .login-logo{text-align:center;margin-bottom:var(--spacing-xl)}.login-card .login-logo .logo-mark{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-500),var(--primary-700));border-radius:16px;display:inline-flex;align-items:center;justify-content:center;font-size:16px;font-weight:800;letter-spacing:-.02em;color:#fff;margin-bottom:var(--spacing-md)}.login-card .login-logo h2{font-size:var(--font-size-2xl);color:var(--gray-900);font-weight:700}.login-card .login-logo p{color:var(--gray-500);margin-top:var(--spacing-xs)}.login-card .form-input{height:48px;background:var(--gray-50);border-color:var(--gray-200)}.login-card .btn-primary{width:100%;height:48px;font-size:var(--font-size-md);margin-top:var(--spacing-sm)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .3s ease}.animate-slide-up{animation:slideInUp .4s ease}.chat-layout{display:grid;grid-template-columns:300px 1fr;height:calc(100vh - var(--topbar-height) - var(--spacing-lg) * 2);background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden}.chat-sidebar{border-right:1px solid var(--gray-200);display:flex;flex-direction:column}.chat-sidebar-header{padding:var(--spacing-md);border-bottom:1px solid var(--gray-100)}.chat-room-list{flex:1;overflow-y:auto}.chat-room-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);cursor:pointer;transition:background var(--transition-fast)}.chat-room-item:hover,.chat-room-item.active{background:var(--primary-50)}.chat-main{display:flex;flex-direction:column}.chat-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--gray-100);font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.chat-msg{max-width:70%;padding:var(--spacing-sm) var(--spacing-md);border-radius:14px;font-size:var(--font-size-sm);line-height:1.5}.chat-msg.sent{align-self:flex-end;background:var(--primary-500);color:#fff;border-bottom-right-radius:4px}.chat-msg.received{align-self:flex-start;background:var(--gray-100);color:var(--gray-800);border-bottom-left-radius:4px}.chat-input-area{padding:var(--spacing-md);border-top:1px solid var(--gray-100);display:flex;gap:var(--spacing-sm)}.chat-input-area input{flex:1;height:42px;border:1px solid var(--gray-200);border-radius:21px;padding:0 var(--spacing-md);font-family:var(--font-family);font-size:var(--font-size-sm)}.chat-input-area input:focus{outline:none;border-color:var(--primary-300)}.email-layout{display:grid;grid-template-columns:220px 350px 1fr;height:calc(100vh - var(--topbar-height) - var(--spacing-lg) * 2);background:var(--card-bg);border-radius:var(--card-radius);box-shadow:var(--card-shadow);overflow:hidden}.email-folders{border-right:1px solid var(--gray-200);padding:var(--spacing-md)}.email-folder-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px var(--spacing-sm);border-radius:8px;cursor:pointer;font-size:var(--font-size-sm);font-weight:500;color:var(--gray-600);transition:all var(--transition-fast)}.email-folder-item:hover,.email-folder-item.active{background:var(--primary-50);color:var(--primary-700)}.email-folder-item .folder-count{margin-left:auto;font-size:var(--font-size-xs);color:var(--gray-400);font-weight:600}.email-list{border-right:1px solid var(--gray-200);overflow-y:auto}.email-item{padding:var(--spacing-md);border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background var(--transition-fast)}.email-item:hover{background:var(--gray-50)}.email-item.active{background:var(--primary-50)}.email-item.unread{border-left:3px solid var(--primary-500)}.email-item-from{font-weight:600;color:var(--gray-800);font-size:var(--font-size-sm);margin-bottom:2px}.email-item-subject{font-size:var(--font-size-sm);color:var(--gray-700);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.email-item-preview{font-size:var(--font-size-xs);color:var(--gray-400);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.email-detail{padding:var(--spacing-lg);overflow-y:auto}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);border:1px solid var(--gray-200);border-radius:var(--card-radius);overflow:hidden}.calendar-header-cell{padding:var(--spacing-sm);text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--gray-500);text-transform:uppercase;background:var(--gray-50);border-bottom:1px solid var(--gray-200)}.calendar-cell{min-height:100px;padding:var(--spacing-xs);border-right:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);cursor:pointer;transition:background var(--transition-fast)}.calendar-cell:hover{background:var(--gray-50)}.calendar-cell:nth-child(7n){border-right:none}.calendar-cell .day-number{font-size:var(--font-size-sm);font-weight:500;color:var(--gray-700);padding:2px 6px;border-radius:6px}.calendar-cell.today .day-number{background:var(--primary-500);color:#fff}.calendar-cell.other-month .day-number{color:var(--gray-300)}.calendar-event{font-size:11px;padding:2px 6px;border-radius:4px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.calendar-event.personal{background:var(--primary-50);color:var(--primary-700)}.calendar-event.dept{background:var(--success-bg);color:#2b8a3e}.calendar-event.meeting{background:#fff4e6;color:#e67700}.kanban-board{display:flex;gap:var(--spacing-md);overflow-x:auto;padding-bottom:var(--spacing-md)}.kanban-column{min-width:300px;background:var(--gray-50);border-radius:var(--card-radius);padding:var(--spacing-md)}.kanban-column-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:2px solid}.kanban-column-header h4{font-size:var(--font-size-sm);font-weight:600}.kanban-card{background:var(--card-bg);border-radius:10px;padding:var(--spacing-md);box-shadow:var(--card-shadow);margin-bottom:var(--spacing-sm);cursor:pointer;transition:all var(--transition-fast)}.kanban-card:hover{transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.kanban-card h5{font-size:var(--font-size-sm);font-weight:600;color:var(--gray-800);margin-bottom:var(--spacing-xs)}.kanban-card p{font-size:var(--font-size-xs);color:var(--gray-500)}.progress-bar{height:6px;background:var(--gray-200);border-radius:3px;overflow:hidden}.progress-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));transition:width var(--transition-base)}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:var(--z-modal);display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease}.modal{background:var(--card-bg);border-radius:16px;width:90%;max-width:560px;max-height:90vh;overflow-y:auto;animation:slideInUp .3s ease}.modal-header{padding:var(--spacing-lg);border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between}.modal-header h3{font-size:var(--font-size-lg);font-weight:600}.modal-body{padding:var(--spacing-lg)}.modal-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--gray-100);display:flex;justify-content:flex-end;gap:var(--spacing-sm)}.org-tree{display:flex;gap:var(--spacing-lg)}.newsfeed-shell{display:grid;grid-template-columns:240px minmax(0,1fr) 320px;gap:var(--spacing-lg);align-items:start}.newsfeed-sidebar-left,.newsfeed-main,.newsfeed-sidebar-right{display:grid;gap:var(--spacing-md)}.feed-sidebar-card,.feed-composer-card,.feed-toolbar-card,.feed-widget-card{background:linear-gradient(180deg,#fffffffa,#ffffffeb);border:1px solid rgba(92,124,250,.08);border-radius:20px;box-shadow:0 18px 40px #1a1f3614}.feed-sidebar-card,.feed-widget-card{padding:var(--spacing-lg)}.feed-collapse-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:transparent;border:none;padding:0;cursor:pointer;text-align:left;margin-bottom:var(--spacing-sm)}.feed-collapse-toggle h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.feed-collapse-arrow{color:var(--text-muted);transition:transform .2s ease}.feed-collapse-arrow.open{transform:rotate(90deg)}.feed-sidebar-card>.form-input{width:100%}.feed-sidebar-card .feed-chip-list{margin-top:0}.feed-sidebar-card h3,.feed-widget-header h3,.feed-composer-header h3{font-size:var(--font-size-lg);color:var(--gray-900)}.feed-sidebar-hero{background:radial-gradient(circle at top left,rgba(92,124,250,.22),transparent 42%),linear-gradient(145deg,#fff,#eef2ff 55%,#f8f9fa)}.feed-hero-kicker,.feed-section-kicker{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:var(--primary-50);color:var(--primary-700);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:var(--spacing-sm)}.contract-layout,.contract-designer-layout{display:grid;grid-template-columns:260px minmax(0,1fr) 360px;gap:var(--spacing-lg);align-items:start}.contract-designer-layout{grid-template-columns:340px minmax(0,1fr)}.contract-rail,.contract-detail,.contract-main .card,.contract-designer-layout .card{min-height:220px}.contract-count-grid,.contract-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-sm)}.contract-count-card,.contract-stat-grid>div,.contract-mini-item,.contract-designer-field{border:1px solid var(--gray-200);border-radius:14px;padding:var(--spacing-md);background:var(--gray-50)}.contract-count-card strong,.contract-stat-grid strong{display:block;font-size:var(--font-size-xl)}.contract-count-card span,.contract-stat-grid span,.contract-list-meta,.contract-mini-item span{color:var(--gray-500);font-size:var(--font-size-sm)}.contract-nav-list,.contract-list,.contract-detail-stack,.contract-mini-list,.contract-designer-fields{display:grid;gap:var(--spacing-sm)}.contract-nav-item,.contract-list-item{border:1px solid var(--gray-200);border-radius:14px;padding:var(--spacing-md);background:#fff;text-align:left;cursor:pointer}.contract-nav-item.active,.contract-list-item.active{border-color:var(--primary-400);background:var(--primary-50)}.contract-list-item-top,.contract-inline-actions{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.contract-list-item p,.contract-detail-stack p{color:var(--gray-600)}.contract-compose-grid,.contract-designer-meta,.contract-designer-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md)}.contract-field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-sm)}.contract-form-list{display:grid;gap:var(--spacing-sm)}.contract-form-row{display:grid;grid-template-columns:120px repeat(3,minmax(0,1fr));gap:var(--spacing-sm)}.contract-sign-shell{min-height:100vh;padding:var(--spacing-2xl) var(--spacing-lg);background:radial-gradient(circle at top left,rgba(59,130,246,.16),transparent 38%),linear-gradient(160deg,#f8fafc,#e2e8f0)}.contract-sign-card{width:min(840px,100%);margin:0 auto;background:#fff;border-radius:24px;border:1px solid rgba(59,130,246,.12);padding:var(--spacing-2xl);box-shadow:0 24px 60px #0f172a1f}.contract-sign-header,.contract-sign-form{display:grid;gap:var(--spacing-md)}.contract-sign-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);color:var(--gray-500)}@media(max-width:1100px){.contract-layout,.contract-designer-layout{grid-template-columns:1fr}}@media(max-width:768px){.contract-compose-grid,.contract-designer-meta,.contract-designer-grid,.contract-field-grid,.contract-form-row{grid-template-columns:1fr}}.feed-sidebar-hero h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-xs)}.feed-sidebar-hero p,.feed-widget-header p,.feed-composer-header p{color:var(--gray-600);font-size:var(--font-size-sm)}.feed-filter-stack{display:grid;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.feed-filter-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--spacing-xs)}.feed-filter-button,.feed-pin-button,.feed-chip,.feed-toggle-button,.feed-widget-item,.feed-card{border:none;background:transparent;cursor:pointer;font-family:inherit}.feed-filter-button{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:12px 14px;border-radius:14px;background:var(--gray-50);color:var(--gray-700);transition:all var(--transition-fast)}.feed-filter-button.active{background:linear-gradient(135deg,var(--primary-600),var(--primary-400));color:#fff;box-shadow:0 14px 28px #4c6ef538}.feed-filter-button:hover:not(.active),.feed-pin-button:hover,.feed-chip:hover,.feed-toggle-button:hover,.feed-widget-item:hover,.feed-card:hover{transform:translateY(-1px)}.feed-pin-button{padding:0 14px;border-radius:14px;background:var(--gray-100);color:var(--gray-700);font-size:var(--font-size-xs);font-weight:700}.feed-pin-button.active{background:var(--warning-bg);color:#9c6f00}.feed-chip-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.feed-chip{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:8px;background:var(--bg-card);border:1px solid var(--border-color);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s ease;width:100%}.feed-chip:hover{background:var(--bg-hover);border-color:var(--primary-light)}.feed-sidebar-empty,.feed-widget-empty,.feed-empty{padding:var(--spacing-md);border-radius:16px;background:var(--gray-50);color:var(--gray-500);font-size:var(--font-size-sm)}.feed-composer-card,.feed-toolbar-card{padding:var(--spacing-lg)}.feed-composer-form,.feed-composer-row,.feed-search-form,.feed-toolbar-actions,.feed-toggle-group,.feed-card-list,.feed-card-top,.feed-card-meta,.feed-card-footer,.feed-card-stats{display:flex}.feed-composer-form{flex-direction:column;gap:var(--spacing-sm)}.feed-composer-row{align-items:center;gap:var(--spacing-sm)}.feed-checkbox{display:inline-flex;align-items:center;gap:8px;color:var(--gray-600);font-size:var(--font-size-sm)}.feed-composer-textarea{min-height:132px;resize:vertical}.feed-composer-actions{display:flex;justify-content:flex-end}.feed-toolbar-card{gap:var(--spacing-md)}.feed-search-form{gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.feed-search-form .form-input{flex:1}.feed-toolbar-actions{justify-content:space-between;flex-wrap:wrap;gap:var(--spacing-sm)}.feed-toggle-group{gap:var(--spacing-xs)}.feed-toggle-button{padding:10px 14px;border-radius:14px;background:var(--gray-100);color:var(--gray-700);font-size:var(--font-size-sm);font-weight:600}.feed-toggle-button.active{background:var(--gray-900);color:#fff}.feed-toggle-button:disabled{opacity:.45;cursor:not-allowed;transform:none}.feed-card-list{flex-direction:column;gap:var(--spacing-md)}.feed-card{width:100%;text-align:left;padding:var(--spacing-lg);border-radius:22px;background:linear-gradient(180deg,#fffffffa,#f8f9faf5);border:1px solid rgba(33,37,41,.06);box-shadow:0 18px 32px #0f172a14}.feed-card.activity{background:radial-gradient(circle at top right,rgba(255,243,191,.55),transparent 42%),linear-gradient(180deg,#fffdf7,#fff 65%)}.feed-card-top,.feed-card-meta,.feed-card-footer{justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.feed-card-top-left{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.feed-author-link{display:inline-flex;align-items:center;gap:6px;background:transparent;border:none;padding:0;margin:0;cursor:pointer;text-align:left;color:var(--text-primary);font-size:.9rem}.feed-author-link:hover strong{text-decoration:underline}.feed-author-link strong{font-weight:600}.feed-avatar-sm{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--primary);color:#fff;font-size:.75rem;font-weight:700}.feed-card-top{display:flex;margin-bottom:var(--spacing-sm)}.feed-card-top small,.feed-card-meta span,.feed-card-footer span,.feed-card-footer small{color:var(--gray-500);font-size:var(--font-size-xs)}.feed-card-meta{flex-wrap:wrap;margin-bottom:var(--spacing-xs)}.feed-card h4{font-size:var(--font-size-xl);color:var(--gray-900);margin-bottom:var(--spacing-sm)}.feed-card-preview{color:var(--gray-700);display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:var(--spacing-md);white-space:pre-wrap}.feed-card-preview.summary{-webkit-line-clamp:3;line-clamp:3}.feed-card-preview.expanded{-webkit-line-clamp:8;line-clamp:8}.feed-card-stats{gap:var(--spacing-sm)}.feed-pagination{display:flex;align-items:center;justify-content:center;gap:var(--spacing-md)}.feed-widget-list{display:grid;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.feed-widget-item{width:100%;text-align:left;padding:14px;border-radius:16px;background:var(--gray-50);display:grid;grid-template-columns:minmax(0,1fr) auto;gap:var(--spacing-sm)}.feed-widget-item-main{display:grid;gap:4px}.feed-widget-item-main strong{color:var(--gray-900)}.feed-widget-item-main span,.feed-widget-item-main p,.feed-widget-item-meta small{color:var(--gray-500);font-size:var(--font-size-xs)}.feed-widget-item-meta{display:grid;justify-items:end;gap:6px}.newsfeed-detail-modal{max-width:760px}.newsfeed-detail-body{display:grid;gap:var(--spacing-lg)}.newsfeed-detail-meta,.newsfeed-comment-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center;color:var(--gray-500);font-size:var(--font-size-sm)}.newsfeed-detail-content{padding:var(--spacing-lg);border-radius:18px;background:var(--gray-50);white-space:pre-wrap;color:var(--gray-800)}.newsfeed-detail-comments{display:grid;gap:var(--spacing-sm)}.newsfeed-comment{padding:var(--spacing-md);border-radius:16px;background:var(--gray-50)}.newsfeed-comment p{margin-top:var(--spacing-xs);white-space:pre-wrap}.feed-card-title-button,.feed-profile-button,.feed-action-button{border:none;background:transparent;font:inherit;cursor:pointer}.feed-card-title-button{width:100%;text-align:left}.feed-profile-button{width:100%;display:flex;align-items:center;gap:var(--spacing-sm);padding:0;color:inherit;margin-bottom:var(--spacing-sm)}.feed-profile-button.static{cursor:default}.feed-profile-button span:last-child{display:grid;gap:4px;text-align:left}.feed-profile-button small{color:var(--gray-500);font-size:var(--font-size-xs)}.feed-avatar{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));color:#fff;font-weight:700;flex-shrink:0}.feed-avatar.xl{width:56px;height:56px;font-size:var(--font-size-lg)}.feed-action-row{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.feed-action-row.compact{gap:var(--spacing-xs)}.feed-action-button{padding:8px 12px;border-radius:999px;background:var(--gray-100);color:var(--gray-700);font-size:var(--font-size-xs);font-weight:700}.feed-action-button.active{background:#4c6ef51f;color:var(--primary-700)}.feed-user-card,.feed-inline-item,.feed-recommend-card{display:grid;gap:var(--spacing-sm);padding:var(--spacing-md);border-radius:16px;background:var(--gray-50)}.feed-inline-item{grid-template-columns:minmax(0,1fr) auto;align-items:center}.feed-inline-item strong,.feed-recommend-card strong{color:var(--gray-900)}.feed-inline-item small,.feed-recommend-card span,.feed-recommend-card p{color:var(--gray-500);font-size:var(--font-size-xs)}.feed-recommend-card p{margin:0}.feed-chip.active{background:#4c6ef524;color:var(--primary-700)}.profile-sheet{max-width:1080px}.profile-layout{display:grid;gap:var(--spacing-lg)}.profile-main-card{display:grid;gap:var(--spacing-md);padding:var(--spacing-lg);border-radius:20px;background:var(--gray-50)}.profile-side-grid{display:grid;gap:var(--spacing-lg);grid-template-columns:repeat(2,minmax(0,1fr))}.compact-card{padding:var(--spacing-lg)}.profile-meta-grid{display:grid;grid-template-columns:96px minmax(0,1fr);gap:var(--spacing-sm) var(--spacing-md);align-items:center}.profile-meta-grid span{color:var(--gray-500);font-size:var(--font-size-sm)}.profile-meta-grid strong{color:var(--gray-900);font-size:var(--font-size-sm)}@media(max-width:1280px){.newsfeed-shell{grid-template-columns:220px minmax(0,1fr)}.newsfeed-sidebar-right{grid-column:1 / -1;grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:960px){.newsfeed-shell,.newsfeed-sidebar-left,.newsfeed-sidebar-right{grid-template-columns:1fr}.feed-search-form,.feed-toolbar-actions{flex-direction:column}.feed-toolbar-actions{align-items:stretch}.feed-toggle-group{width:100%}.feed-toggle-button{flex:1}.profile-side-grid{grid-template-columns:1fr}}.dept-tree{width:280px;flex-shrink:0}.dept-tree-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px var(--spacing-sm);border-radius:8px;cursor:pointer;font-size:var(--font-size-sm);color:var(--gray-700);transition:all var(--transition-fast)}.dept-tree-item:hover,.dept-tree-item.active{background:var(--primary-50);color:var(--primary-700)}.dept-tree-children{padding-left:var(--spacing-lg)}.member-grid{flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-md);align-content:start}.member-card{background:var(--card-bg);border-radius:var(--card-radius);padding:var(--spacing-lg);box-shadow:var(--card-shadow);text-align:center;transition:all var(--transition-base);cursor:pointer}.member-card:hover{transform:translateY(-3px);box-shadow:var(--card-shadow-hover)}.member-card .member-avatar{width:64px;height:64px;border-radius:16px;margin:0 auto var(--spacing-md);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:700;color:#fff}.member-card .member-name{font-weight:600;color:var(--gray-800);margin-bottom:var(--spacing-xs)}.member-card .member-role{font-size:var(--font-size-xs);color:var(--gray-500)}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.room-card{background:var(--card-bg);border-radius:var(--card-radius);padding:var(--spacing-lg);box-shadow:var(--card-shadow);transition:all var(--transition-base)}.room-card:hover{box-shadow:var(--card-shadow-hover)}@media(max-width:768px){.sidebar{width:var(--sidebar-collapsed-width)}.topbar{left:var(--sidebar-collapsed-width)}.main-content{margin-left:var(--sidebar-collapsed-width)}.topbar-user-info{display:none}.topbar-user{padding-right:6px}.topbar-panel{right:-8px}.email-layout,.chat-layout,.stat-grid{grid-template-columns:1fr}}.btn-ghost{background:transparent;color:var(--gray-600);border:1px solid var(--gray-200)}.btn-ghost:hover{background:var(--gray-50);color:var(--gray-800)}.alert{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);border-radius:14px;margin-bottom:var(--spacing-md);font-size:var(--font-size-sm);font-weight:500}.alert-success{background:#ebfbee;border:1px solid #b2f2bb;color:#2b8a3e}.alert-error{background:#fff5f5;border:1px solid #ffc9c9;color:#c92a2a}.approval-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:var(--spacing-lg)}.approval-main{min-width:0}.approval-nav-card,.approval-card{background:var(--card-bg);border-radius:18px;box-shadow:var(--card-shadow)}.approval-nav-card{position:sticky;top:96px;align-self:start;padding:var(--spacing-lg);display:grid;gap:var(--spacing-md)}.approval-create-btn{width:100%}.approval-nav-list{display:grid;gap:6px}.approval-nav-item{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:12px 14px;border:1px solid transparent;border-radius:12px;background:transparent;color:var(--gray-700);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:600;text-align:left;cursor:pointer}.approval-nav-item:hover{background:var(--gray-50)}.approval-nav-item.active{background:var(--primary-50);border-color:var(--primary-100);color:var(--primary-700)}.approval-list-detail{display:grid;grid-template-columns:minmax(340px,420px) minmax(0,1fr);gap:var(--spacing-lg);align-items:start}.approval-compose-layout{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:var(--spacing-lg);align-items:start}.approval-side-rail{display:grid;gap:var(--spacing-lg);align-self:start}.approval-card{padding:var(--spacing-lg)}.approval-card.nested{padding:var(--spacing-lg);box-shadow:none;border:1px solid var(--gray-100);background:linear-gradient(180deg,#ffffff 0%,var(--gray-50) 100%)}.approval-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.approval-card-header h3{margin:0 0 6px;font-size:var(--font-size-lg)}.approval-card-header p{margin:0;color:var(--gray-500);font-size:var(--font-size-sm)}.approval-status-tabs{margin-bottom:var(--spacing-md)}.approval-tab-count{margin-left:6px;font-size:var(--font-size-xs);opacity:.8}.approval-filter-grid{display:grid;grid-template-columns:minmax(220px,1fr) repeat(3,minmax(0,180px));gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.approval-filter-actions{display:flex;gap:var(--spacing-sm)}.approval-table tbody tr.active td{background:var(--primary-50)}.approval-table tbody tr{cursor:pointer}.approval-table-title{display:grid;gap:4px}.approval-table-title strong{color:var(--gray-900)}.approval-table-title span{font-size:var(--font-size-xs);color:var(--gray-500)}.approval-pagination{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md);flex-wrap:wrap}.approval-template-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-md)}.approval-template-card{display:grid;gap:8px;padding:var(--spacing-lg);border:1px solid var(--gray-200);border-radius:16px;background:linear-gradient(180deg,#ffffff 0%,var(--gray-50) 100%);text-align:left;cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast)}.approval-template-card:hover{border-color:var(--primary-200);transform:translateY(-2px);box-shadow:var(--card-shadow-hover)}.approval-template-card strong{color:var(--gray-900);font-size:var(--font-size-md)}.approval-template-card span{color:var(--gray-500);font-size:var(--font-size-sm);line-height:1.6}.approval-range-inputs{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:var(--spacing-sm)}.approval-inline-stat{display:grid;gap:6px;padding:var(--spacing-md);border:1px solid var(--primary-100);border-radius:12px;background:var(--primary-50);align-content:center}.approval-inline-stat strong{font-size:var(--font-size-sm);color:var(--primary-700)}.approval-inline-stat span{font-size:var(--font-size-sm);color:var(--gray-700)}.approval-side-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm)}.approval-small-muted{font-size:var(--font-size-xs);color:var(--gray-500)}.approval-line-list,.approval-choice-list,.approval-bookmark-list,.approval-opinion-list,.approval-chip-list,.approval-file-list{display:grid;gap:var(--spacing-sm)}.approval-choice-list{max-height:220px;overflow-y:auto}.approval-line-item,.approval-choice-item,.approval-chip,.approval-opinion-item,.approval-bookmark-item{border:1px solid var(--gray-200);border-radius:12px;background:#fff}.approval-line-item,.approval-bookmark-item{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm);padding:12px 14px}.approval-line-item.current{border-color:var(--primary-200);background:var(--primary-50)}.approval-line-item strong,.approval-chip strong,.approval-opinion-head strong{display:block;color:var(--gray-900)}.approval-line-item span,.approval-chip span,.approval-opinion-head span{color:var(--gray-500);font-size:var(--font-size-xs)}.approval-line-actions,.approval-action-row,.approval-bookmark-form{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.approval-choice-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:12px 14px}.approval-bookmark-apply{display:grid;gap:4px;border:none;background:transparent;padding:0;text-align:left;color:inherit;cursor:pointer;flex:1}.approval-chip{padding:12px 14px}.approval-file-link{display:flex;align-items:center;gap:8px;padding:12px 14px;border:1px solid var(--gray-200);border-radius:12px;background:#fff;color:var(--primary-700);text-decoration:none;font-size:var(--font-size-sm)}.approval-file-link:hover{border-color:var(--primary-200);background:var(--primary-50)}.approval-document-sheet{padding:40px 44px;border:1px solid var(--gray-200);border-radius:18px;background:#fff;box-shadow:0 16px 32px #0f172a0f;color:var(--gray-800);line-height:1.75}.approval-document-sheet h2{margin-top:0;margin-bottom:0;font-size:1.8rem;text-align:center;letter-spacing:-.02em;color:var(--gray-900)}.approval-document-sheet table{width:100%;border-collapse:collapse}.approval-document-sheet th,.approval-document-sheet td{padding:12px 14px;border:1px solid var(--gray-200);text-align:left;vertical-align:top}.approval-document-sheet th{width:180px;background:var(--gray-50);color:var(--gray-700)}.approval-compose-document{display:grid;gap:var(--spacing-lg)}.approval-doc-header{display:grid;justify-items:center;gap:12px;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:2px solid var(--gray-100);text-align:center}.approval-doc-kicker{display:inline-flex;align-items:center;width:fit-content;padding:6px 10px;border-radius:999px;border:1px solid var(--gray-200);background:#fff;color:var(--gray-600);font-size:var(--font-size-xs);font-weight:700}.approval-doc-header p{margin:0;max-width:620px;color:var(--gray-600);font-size:var(--font-size-sm);line-height:1.7}.approval-doc-meta-table,.approval-doc-body-table{table-layout:fixed}.approval-doc-meta-table th{width:112px}.approval-doc-body-table th{width:148px}.approval-doc-table td{background:#fff}.approval-doc-control{min-height:44px;border-color:var(--gray-200);background:var(--gray-25)}.approval-doc-control--compact{min-height:40px;padding-top:8px;padding-bottom:8px}.approval-doc-control--textarea{min-height:148px;resize:vertical}.approval-doc-range{gap:10px}.approval-doc-option-group{display:flex;flex-wrap:wrap;gap:10px}.approval-doc-pill{position:relative;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--gray-200);border-radius:999px;background:var(--gray-25);color:var(--gray-700);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.approval-doc-pill input,.approval-doc-checkbox input{accent-color:var(--primary-500)}.approval-doc-pill.active,.approval-doc-checkbox.active{border-color:var(--primary-200);background:var(--primary-50);color:var(--primary-700)}.approval-doc-checkbox{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--gray-200);border-radius:12px;background:var(--gray-25);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast)}.approval-doc-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--spacing-sm)}.approval-doc-stat{display:grid;gap:6px;padding:16px;border:1px solid var(--primary-100);border-radius:16px;background:linear-gradient(180deg,#eff6ffeb,#fff)}.approval-doc-stat strong{color:var(--primary-700);font-size:var(--font-size-xs);letter-spacing:.01em}.approval-doc-stat span{color:var(--gray-900);font-size:var(--font-size-md);font-weight:700}.approval-doc-callout{display:grid;gap:6px;padding:16px 18px;border:1px solid rgba(245,158,11,.28);border-radius:16px;background:linear-gradient(180deg,#fffbebeb,#fff)}.approval-doc-callout strong{color:#b45309;font-size:var(--font-size-sm)}.approval-doc-callout p{margin:0;color:var(--gray-700);line-height:1.7}.approval-detail-layout{display:grid;grid-template-columns:minmax(0,1fr);gap:var(--spacing-lg)}.approval-detail-main{display:grid;gap:var(--spacing-lg);min-width:0}.approval-detail-layout>.approval-side-rail{grid-template-columns:repeat(3,minmax(0,1fr));align-self:stretch}.approval-detail-layout>.approval-side-rail .form-section{height:100%;align-content:start}.approval-detail-card{padding:var(--spacing-xl)}.approval-detail-heading{align-items:flex-start;margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--gray-100)}.approval-detail-kicker{display:inline-flex;align-items:center;margin-bottom:8px;padding:5px 10px;border-radius:999px;background:var(--gray-50);color:var(--gray-600);font-size:11px;font-weight:700;letter-spacing:.04em}.approval-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--spacing-sm)}.approval-meta-item{min-width:0;padding:16px 18px;border:1px solid rgba(148,163,184,.22);border-radius:14px;background:linear-gradient(180deg,#f8fafcf5,#fff);box-shadow:inset 0 1px #ffffffd9}.approval-meta-item>span{display:block;margin-bottom:6px;color:var(--gray-500);font-size:var(--font-size-xs)}.approval-meta-item strong{display:flex;align-items:center;gap:8px;color:var(--gray-900);font-size:var(--font-size-sm)}.approval-history-table-wrap{overflow-x:auto}.approval-history-table{min-width:760px}.approval-history-table th{text-transform:none;letter-spacing:0;white-space:nowrap}.approval-history-table td{vertical-align:top}.approval-history-user{display:grid;gap:4px}.approval-history-user strong{color:var(--gray-900)}.approval-history-user span{color:var(--gray-500);font-size:var(--font-size-xs)}.approval-opinion-item{padding:14px}.approval-opinion-head{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-bottom:8px}.approval-opinion-item p{margin:0;color:var(--gray-700);line-height:1.7}.approval-empty{display:grid;gap:6px;align-items:center;justify-items:start;min-height:180px;padding:var(--spacing-lg);border:1px dashed var(--gray-200);border-radius:16px;color:var(--gray-500);background:linear-gradient(180deg,#f8fafcb3,#fffffff2)}.approval-empty.compact{min-height:auto;padding:var(--spacing-md)}.approval-empty strong{color:var(--gray-700)}@media(max-width:1280px){.approval-shell,.approval-list-detail,.approval-compose-layout,.approval-detail-layout{grid-template-columns:1fr}.approval-nav-card{position:static}.approval-detail-layout>.approval-side-rail{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.approval-filter-grid,.approval-meta-grid,.approval-range-inputs,.approval-doc-stat-grid{grid-template-columns:1fr}.approval-filter-actions,.approval-action-row,.approval-card-header,.approval-bookmark-item,.approval-line-item,.approval-opinion-head{flex-direction:column;align-items:stretch}.approval-detail-layout>.approval-side-rail{grid-template-columns:1fr}}.topbar-inline-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.topbar-messenger-panel .topbar-panel-message.muted{color:var(--gray-500);margin-top:2px}.topbar-message-room-title{font-weight:700;color:var(--gray-900)}.topbar-panel-dot-count{min-width:22px;height:22px;border-radius:999px;background:var(--primary-600);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 8px;flex-shrink:0}.messenger-popup-shell{min-height:100vh;background:linear-gradient(180deg,#eef2ff,#f8fafc 48%,#f1f5f9)}.messenger-popup-page{min-height:100vh;padding:var(--spacing-lg)}.messenger-shell{display:grid;gap:var(--spacing-lg)}.messenger-layout{display:grid;grid-template-columns:320px minmax(0,1fr) 300px;gap:var(--spacing-lg);align-items:start}.messenger-sidebar,.messenger-main,.messenger-detail-panel{min-width:0}.messenger-panel-card,.messenger-main,.messenger-modal,.messenger-community-modal{background:var(--card-bg);border-radius:22px;box-shadow:var(--card-shadow)}.messenger-panel-card{padding:var(--spacing-lg);display:grid;gap:var(--spacing-md)}.messenger-panel-card+.messenger-panel-card{margin-top:var(--spacing-lg)}.messenger-panel-card.sticky{position:sticky;top:96px}.messenger-panel-head,.messenger-main-header,.messenger-main-title-row,.messenger-room-head,.messenger-detail-actions,.messenger-search-inline,.messenger-composer-tools,.messenger-composer-row,.messenger-room-meta,.messenger-message-foot,.messenger-community-layout,.modal-header-actions{display:flex;gap:var(--spacing-sm)}.messenger-panel-head,.messenger-main-header,.messenger-room-head{justify-content:space-between;align-items:center}.messenger-panel-block,.messenger-detail-section,.messenger-detail-sections,.messenger-main,.messenger-search-panel,.messenger-search-results,.messenger-forward-list,.messenger-community-list-panel,.messenger-community-detail-panel,.messenger-message-stack,.messenger-emoji-group{display:grid;gap:var(--spacing-sm)}.messenger-count-chip,.room-type-pill,.filter-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:var(--font-size-xs);font-weight:700}.messenger-count-chip{min-width:28px;height:28px;padding:0 10px;background:var(--primary-50);color:var(--primary-700)}.room-type-pill{padding:6px 10px;background:#5c7cfa1f;color:var(--primary-700)}.filter-chip{padding:8px 14px;border:none;background:var(--gray-100);color:var(--gray-700);cursor:pointer}.filter-chip.active{background:var(--gray-900);color:#fff}.messenger-filter-row{display:flex;gap:8px;flex-wrap:wrap}.messenger-room-list{display:grid;gap:10px;max-height:460px;overflow-y:auto}.messenger-room-item{display:grid;grid-template-columns:44px minmax(0,1fr) auto;gap:var(--spacing-sm);padding:14px;border:1px solid var(--gray-200);border-radius:18px;background:linear-gradient(180deg,#fff 0%,var(--gray-50) 100%);text-align:left;cursor:pointer}.messenger-room-item.active{border-color:var(--primary-200);background:linear-gradient(180deg,#eef2ffeb,#fff)}.messenger-room-badge{width:44px;height:44px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-600),var(--primary-400));color:#fff;font-weight:700;flex-shrink:0}.messenger-message-avatar{width:40px;height:40px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-500),var(--primary-400));color:#fff;font-weight:700;font-size:var(--font-size-sm);flex-shrink:0;margin-top:2px}.messenger-room-head strong,.messenger-search-item strong,.messenger-participant-item strong,.messenger-main-title-row h3{color:var(--gray-900)}.messenger-room-head span,.messenger-room-snippet,.messenger-main-header p,.messenger-search-item span,.messenger-message-meta span,.messenger-message-foot span,.messenger-participant-item span,.messenger-participant-item small{color:var(--gray-500);font-size:var(--font-size-xs)}.messenger-room-snippet{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messenger-room-unread{min-width:24px;height:24px;padding:0 8px;border-radius:999px;background:var(--primary-600);color:#fff;font-size:11px;font-weight:700;display:inline-flex;align-items:center;justify-content:center}.messenger-main{padding:var(--spacing-lg);min-height:780px}.messenger-main-header{margin-bottom:var(--spacing-md)}.messenger-main-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.messenger-pin-banner,.messenger-search-panel{margin-bottom:var(--spacing-md);padding:var(--spacing-md);border:1px solid var(--gray-200);border-radius:18px;background:linear-gradient(180deg,#fffbebf0,#fff)}.messenger-message-stream{min-height:420px;max-height:520px;overflow-y:auto;padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 0;display:grid;gap:4px}.messenger-day-divider{display:flex;justify-content:center;margin:14px 0}.messenger-day-divider span{padding:6px 14px;border-radius:999px;background:var(--gray-100);color:var(--gray-600);font-size:var(--font-size-xs);font-weight:700}.messenger-message-row{display:flex;gap:var(--spacing-sm)}.messenger-message-row.highlighted .messenger-bubble,.messenger-message-row.highlighted .messenger-system-message{box-shadow:0 0 0 3px #5c7cfa29}.messenger-message-stack{max-width:min(70%,640px)}.messenger-bubble{padding:10px 14px;border-radius:18px;border:none;background:var(--gray-100);line-height:1.5;font-size:var(--font-size-sm)}.messenger-bubble.theirs{border-radius:4px 18px 18px}.messenger-bubble.mine{background:var(--primary-500);color:#fff;border-radius:18px 4px 18px 18px}.messenger-forward-chip{margin-bottom:10px;padding:8px 10px;border-radius:12px;background:#0f172a14;font-size:var(--font-size-xs)}.messenger-system-message{padding:10px 16px;border-radius:999px;background:var(--gray-100);color:var(--gray-700);font-size:var(--font-size-sm)}.messenger-attachment-list,.messenger-selected-files,.messenger-emoji-grid,.messenger-participant-list,.messenger-check-list,.messenger-message-menu{display:grid;gap:10px}.messenger-attachment-item,.messenger-search-item,.messenger-participant-item,.messenger-check-item{display:grid;gap:4px;padding:12px 14px;border:1px solid var(--gray-200);border-radius:14px;background:var(--gray-50)}.messenger-search-item{text-align:left;border:none;cursor:pointer}.messenger-check-item small{grid-column:2 / span 1;color:var(--gray-500)}.messenger-message-menu{justify-items:start}.messenger-message-menu button{border:none;background:#fff;padding:10px 12px;border-radius:12px;cursor:pointer;box-shadow:var(--card-shadow)}.messenger-composer{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--gray-100);display:grid;gap:var(--spacing-sm)}.messenger-textarea{min-height:104px}.messenger-composer-row .btn{min-width:96px}.messenger-emoji-panel{padding:var(--spacing-md);border:1px solid var(--gray-200);border-radius:16px;background:#fff;display:grid;gap:var(--spacing-md)}.messenger-emoji-grid button{border:none;background:var(--gray-50);border-radius:12px;padding:12px;font-size:1.2rem;cursor:pointer}.messenger-modal,.messenger-community-modal{width:min(860px,calc(100vw - 32px))}.messenger-community-modal{width:min(1200px,calc(100vw - 32px))}.messenger-community-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:var(--spacing-lg)}.max-grid{max-height:220px;overflow-y:auto}.modal-backdrop{position:fixed;inset:0;z-index:var(--z-modal);background:#0f172a8c;display:flex;align-items:center;justify-content:center;padding:var(--spacing-lg)}.modal-panel{width:min(1180px,calc(100vw - 32px));max-height:calc(100vh - 48px);overflow:auto;background:var(--card-bg);border-radius:24px;box-shadow:0 24px 80px #0f172a38}.modal-close{border:none;background:transparent;color:var(--gray-500);font-size:1.5rem;cursor:pointer}.community-layout{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;gap:var(--spacing-lg);align-items:start}.community-rail,.community-main,.community-side{min-width:0}.community-main,.community-side{display:grid;gap:var(--spacing-md)}.community-view-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-xs);margin:var(--spacing-md) 0}.community-view-tab{border:1px solid var(--gray-200);background:var(--gray-50);border-radius:12px;padding:10px 12px;font-weight:600;cursor:pointer}.community-view-tab.active{background:var(--primary-50);color:var(--primary-700);border-color:var(--primary-200)}.community-sidebar-label{margin:var(--spacing-md) 0 var(--spacing-xs);font-size:var(--font-size-xs);font-weight:700;color:var(--gray-500);letter-spacing:.08em;text-transform:uppercase}.community-nav-list,.community-member-list,.community-selector-list{display:grid;gap:var(--spacing-sm)}.community-nav-item,.community-post-card{border:1px solid var(--gray-200);background:#fff;border-radius:16px;padding:14px;text-align:left;cursor:pointer;display:grid;gap:6px;transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast)}.community-nav-item:hover,.community-post-card:hover{transform:translateY(-1px);box-shadow:var(--card-shadow-hover)}.community-nav-item.active{border-color:var(--primary-300);background:linear-gradient(180deg,#eff6fff2,#fff)}.community-nav-item strong,.community-post-card strong{font-size:var(--font-size-base);color:var(--gray-900)}.community-nav-item span,.community-post-card p,.community-post-meta,.community-meta-row{font-size:var(--font-size-sm);color:var(--gray-500)}.community-hero{overflow:hidden;padding:0}.community-cover{height:180px;background:linear-gradient(135deg,#3b82f629,#0ea5e914)}.community-cover img,.community-cover-fallback{width:100%;height:100%;object-fit:cover}.community-hero-body{padding:var(--spacing-lg);display:grid;gap:var(--spacing-md)}.community-badge-row,.community-meta-row,.community-action-row,.community-inline-actions,.community-post-top,.community-post-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);align-items:center}.community-post-list,.community-info-grid{display:grid;gap:var(--spacing-md)}.community-info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.community-info-card{padding:var(--spacing-md);border:1px solid var(--gray-200);border-radius:16px;background:var(--gray-50)}.community-info-card strong{display:block;margin-bottom:6px}.community-side-list{display:grid;gap:var(--spacing-sm)}.community-side-list div{display:flex;justify-content:space-between;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.community-member-item{border:1px solid var(--gray-200);border-radius:14px;padding:12px;display:grid;gap:var(--spacing-sm)}.community-member-item strong{display:block}.community-member-item span,.community-member-item small{color:var(--gray-500)}.community-member-actions{display:flex;gap:var(--spacing-sm);align-items:center}.community-selector-item{display:flex;gap:var(--spacing-sm);align-items:center;padding:10px 12px;border:1px solid var(--gray-200);border-radius:12px;background:#fff}.community-placeholder{padding:18px;border:1px dashed var(--gray-300);border-radius:16px;color:var(--gray-500);font-size:var(--font-size-sm)}.community-form-modal{width:min(1100px,calc(100vw - 32px))}.community-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--spacing-md)}.community-form-grid .form-span-2{grid-column:1 / -1}@media(max-width:1360px){.messenger-layout{grid-template-columns:300px minmax(0,1fr)}.community-layout{grid-template-columns:260px minmax(0,1fr)}.community-side{grid-column:1 / -1;grid-template-columns:repeat(2,minmax(0,1fr))}.messenger-detail-panel{grid-column:1 / -1}}@media(max-width:960px){.messenger-layout,.messenger-community-layout,.messenger-composer-row,.messenger-main-header,.topbar-inline-actions,.community-layout,.community-side,.community-form-grid{grid-template-columns:1fr;flex-direction:column}.messenger-panel-card.sticky{position:static}.messenger-message-stack{max-width:100%}}.calendar-workspace{display:grid;grid-template-columns:320px minmax(0,1fr);gap:var(--spacing-lg);align-items:start}.calendar-sidebar,.calendar-main,.calendar-sidebar-stack,.calendar-subscription-list,.calendar-list-stack,.calendar-list-items,.calendar-week-stack,.calendar-detail-stack{display:grid;gap:var(--spacing-md)}.calendar-source-button,.calendar-upcoming-item,.calendar-list-item{width:100%;border:1px solid var(--gray-200);background:#fff;border-radius:14px;padding:14px;text-align:left;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.calendar-source-button:hover,.calendar-upcoming-item:hover,.calendar-list-item:hover{border-color:var(--primary-300);box-shadow:var(--card-shadow-hover);transform:translateY(-1px)}.calendar-source-button.active{border-color:var(--primary-400);background:linear-gradient(180deg,#eff6fff2,#fff)}.calendar-source-button,.calendar-subscription-item,.calendar-upcoming-item,.calendar-list-item,.calendar-list-head,.calendar-toolbar,.calendar-toolbar-block,.calendar-inline-actions,.calendar-view-tabs,.calendar-legend,.calendar-query-title,.calendar-detail-row{display:flex;align-items:center;gap:var(--spacing-sm)}.calendar-source-button,.calendar-list-head,.calendar-toolbar,.calendar-toolbar-block,.calendar-detail-row{justify-content:space-between}.calendar-source-button span,.calendar-toolbar-caption,.calendar-subscription-item span,.calendar-upcoming-item span,.calendar-list-item p,.calendar-list-item-meta,.calendar-more-label,.calendar-empty-panel,.calendar-empty-inline,.calendar-detail-note p{color:var(--gray-500);font-size:var(--font-size-sm)}.calendar-subscribe-row,.calendar-query-grid,.calendar-form-grid{display:grid;gap:var(--spacing-sm)}.calendar-subscribe-row{grid-template-columns:minmax(0,1fr) auto}.calendar-subscription-item{justify-content:space-between;padding:12px 14px;border:1px solid var(--gray-200);border-radius:14px;background:var(--gray-50)}.calendar-subscription-item strong,.calendar-upcoming-item strong,.calendar-list-item strong{color:var(--gray-900)}.calendar-upcoming-item{flex-direction:column;align-items:flex-start}.calendar-toolbar,.calendar-toolbar-block,.calendar-view-tabs{flex-wrap:wrap}.calendar-view-tab{border:1px solid var(--gray-200);background:var(--gray-50);color:var(--gray-600);padding:10px 14px;border-radius:999px;cursor:pointer;transition:all var(--transition-fast)}.calendar-view-tab.active{border-color:var(--primary-500);background:var(--primary-500);color:#fff}.calendar-legend{flex-wrap:wrap;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--gray-200)}.calendar-legend span{display:inline-flex;align-items:center;gap:6px;color:var(--gray-600);font-size:var(--font-size-sm)}.calendar-legend i,.calendar-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.calendar-month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:var(--spacing-sm)}.calendar-month-head{padding:10px 12px;border-radius:12px;background:var(--gray-100);color:var(--gray-600);font-weight:700;text-align:center}.calendar-month-cell{min-height:170px;border:1px solid var(--gray-200);border-radius:16px;background:#fff;padding:12px;text-align:left;cursor:pointer;display:grid;align-content:start;gap:var(--spacing-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.calendar-month-cell:hover{border-color:var(--primary-300);box-shadow:var(--card-shadow-hover);transform:translateY(-1px)}.calendar-month-cell.muted{background:var(--gray-50)}.calendar-month-cell.today{border-color:var(--primary-400)}.calendar-month-date-row{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm)}.calendar-month-date{font-size:var(--font-size-base);font-weight:700;color:var(--gray-900)}.calendar-month-event-list{display:grid;gap:6px}.calendar-event-chip{width:100%;border:1px solid transparent;border-radius:12px;padding:10px 12px;background:var(--gray-100);text-align:left;cursor:pointer;display:grid;gap:4px;font-size:var(--font-size-sm)}.calendar-event-chip.compact{padding:8px 10px}.calendar-event-chip strong{font-size:var(--font-size-sm)}.calendar-week-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:var(--spacing-md)}.calendar-week-column{border:1px solid var(--gray-200);border-radius:18px;background:#fff;padding:var(--spacing-md);display:grid;gap:var(--spacing-md)}.calendar-week-head{border:none;background:var(--gray-50);border-radius:14px;padding:12px 14px;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-sm);cursor:pointer}.calendar-list-day,.calendar-query-shell{display:grid;gap:var(--spacing-md)}.calendar-list-head{padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--gray-200)}.calendar-list-item{justify-content:space-between}.calendar-list-item-main,.calendar-list-item-meta{display:grid;gap:6px}.calendar-list-item-meta{justify-items:end;min-width:220px}.calendar-query-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.calendar-query-table-wrap{overflow-x:auto}.calendar-query-table th,.calendar-query-table td{white-space:nowrap}.calendar-query-table tbody tr{cursor:pointer}.calendar-query-title{min-width:0}.calendar-empty-panel{padding:28px;border:1px dashed var(--gray-300);border-radius:18px;background:var(--gray-50);text-align:center}.calendar-empty-inline{padding:14px 0}.calendar-modal{width:min(880px,calc(100vw - 32px))}.calendar-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-detail-stack{gap:var(--spacing-md)}.calendar-detail-row{padding:12px 0;border-bottom:1px solid var(--gray-200)}.calendar-detail-row strong,.calendar-detail-note strong{color:var(--gray-900)}.calendar-detail-note{display:grid;gap:var(--spacing-sm)}.calendar-detail-note p{padding:14px 16px;border-radius:14px;background:var(--gray-50);border:1px solid var(--gray-200)}@media(max-width:1360px){.calendar-workspace{grid-template-columns:280px minmax(0,1fr)}.calendar-week-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:1080px){.calendar-workspace,.calendar-query-grid,.calendar-form-grid,.calendar-week-grid{grid-template-columns:1fr}.calendar-list-item{flex-direction:column;align-items:flex-start}.calendar-list-item-meta{min-width:0;justify-items:start}}@media(max-width:720px){.calendar-month-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.calendar-subscribe-row{grid-template-columns:1fr}.calendar-toolbar,.calendar-toolbar-block,.calendar-inline-actions{flex-direction:column;align-items:stretch}.calendar-view-tabs{width:100%}.calendar-view-tab{flex:1}}.messenger-popup-shell{min-height:100vh;background:#e9eff5}.messenger-shell{--messenger-yellow: #fee500;--messenger-yellow-deep: #f5d400;--messenger-chat-bg: #b9cddd;--messenger-chat-bg-deep: #c8d8e6;--messenger-border: #d8e0e8;--messenger-panel: #f7fafc;display:grid;gap:14px}.messenger-page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:8px}.messenger-page-header p{max-width:560px}.messenger-page-actions{margin-top:0;flex-wrap:wrap;align-items:center}.messenger-shell .btn{border-radius:14px;padding:10px 16px;box-shadow:none;transform:none}.messenger-shell .btn-primary{background:var(--messenger-yellow);color:#241d00;border:1px solid #eed100}.messenger-shell .btn-primary:hover{background:#f8de22;transform:none;box-shadow:none}.messenger-shell .btn-secondary{background:#1f2937;color:#fff}.messenger-shell .btn-secondary:hover{background:#111827}.messenger-shell .btn-outline{background:#ffffffeb;color:var(--gray-700);border:1px solid var(--messenger-border)}.messenger-shell .btn-outline:hover{background:#fff;border-color:#c1ccd8}.messenger-shell .btn-sm{padding:7px 12px;border-radius:12px}.messenger-shell .form-input{height:44px;border-radius:14px;border-color:var(--messenger-border);background:#fff}.messenger-shell textarea.form-input{min-height:88px}.messenger-shell .form-input:focus{border-color:#8aa8c5;box-shadow:0 0 0 3px #ffe50029}.messenger-layout{position:relative;display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px;align-items:stretch}.messenger-drawer-backdrop,.messenger-detail-backdrop{position:fixed;inset:0;z-index:130;border:none;background:#0f172a47;opacity:0;pointer-events:none;transition:opacity .18s ease}.messenger-detail-backdrop.visible{opacity:1;pointer-events:auto}.messenger-sidebar,.messenger-main{min-width:0}.messenger-sidebar{position:sticky;top:86px;align-self:start;height:calc(100vh - 118px);min-height:720px;border:1px solid var(--messenger-border);border-radius:28px;background:var(--messenger-panel);overflow:hidden}.messenger-sidebar-frame{height:100%;display:flex;flex-direction:column;gap:14px;padding:16px}.messenger-sidebar-top,.messenger-main-header,.messenger-main-leading,.messenger-detail-header,.messenger-detail-actions,.messenger-panel-head,.messenger-search-inline,.messenger-composer-tools,.messenger-composer-row,.messenger-room-head,.messenger-room-meta,.messenger-message-foot,.messenger-compose-actions,.messenger-sidebar-top-actions{display:flex;gap:8px}.messenger-sidebar-top,.messenger-main-header,.messenger-detail-header,.messenger-panel-head,.messenger-room-head{justify-content:space-between;align-items:center}.messenger-sidebar-kicker{display:block;margin-bottom:4px;font-size:.68rem;font-weight:800;letter-spacing:.16em;color:var(--gray-500)}.messenger-sidebar-top h3,.messenger-detail-header h3{font-size:1.1rem;color:var(--gray-900)}.messenger-sidebar-top-actions{align-items:center;flex-wrap:wrap;justify-content:flex-end}.messenger-unread-chip,.messenger-count-chip,.room-type-pill,.filter-chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:.72rem;font-weight:700}.messenger-unread-chip{min-height:30px;padding:0 12px;background:#0f172aeb;color:#fff}.messenger-count-chip{min-width:30px;min-height:30px;padding:0 11px;background:#fff;color:var(--gray-700);border:1px solid var(--messenger-border)}.room-type-pill{padding:6px 10px;background:#ffe5003d;color:#5b4b00}.room-type-pill.strong{background:#0f172a14;color:var(--gray-800)}.messenger-sidebar-controls,.messenger-panel-block,.messenger-compose-body,.messenger-room-list-shell,.messenger-search-panel,.messenger-search-results,.messenger-message-stack,.messenger-detail-sections,.messenger-detail-section,.messenger-detail-content,.messenger-emoji-group,.messenger-community-list-panel,.messenger-community-detail-panel,.messenger-forward-list{display:grid;gap:10px}.messenger-compose-panel{border:1px solid var(--messenger-border);border-radius:22px;background:#fff;overflow:hidden}.messenger-compose-panel summary{list-style:none;display:flex;justify-content:space-between;gap:12px;padding:15px 16px;cursor:pointer}.messenger-compose-panel summary::-webkit-details-marker{display:none}.messenger-compose-summary strong{display:block;color:var(--gray-900)}.messenger-compose-summary span{font-size:var(--font-size-xs);color:var(--gray-500)}.messenger-compose-summary-icon{width:30px;height:30px;border-radius:50%;background:#ffe5002e;color:#6b5a00;font-size:1rem;line-height:1}.messenger-compose-panel[open] .messenger-compose-summary-icon{transform:rotate(45deg)}.messenger-compose-body{padding:0 16px 16px}.messenger-compose-actions{flex-wrap:wrap}.messenger-filter-row{display:flex;flex-wrap:wrap;gap:8px}.filter-chip{padding:8px 12px;border:1px solid transparent;background:#ffffffe0;color:var(--gray-600);cursor:pointer}.filter-chip.active{background:#ffe50057;border-color:#eed100;color:#4f4100}.messenger-room-list-shell{min-height:0;flex:1}.messenger-room-list-head{margin-top:2px}.messenger-room-list{flex:1;max-height:none;min-height:0;overflow-y:auto;padding-right:4px;display:grid;gap:10px}.messenger-room-list.compact{max-height:520px}.messenger-room-item{display:grid;grid-template-columns:46px minmax(0,1fr) auto;gap:10px;padding:13px;border:1px solid var(--messenger-border);border-radius:20px;background:#fff;text-align:left;cursor:pointer;transition:border-color .15s ease,background .15s ease,transform .15s ease}.messenger-room-item:hover{transform:translateY(-1px);border-color:#c2cfdb}.messenger-room-item.active{border-color:#ebcf27;background:#fffdf4}.messenger-room-badge,.messenger-main-avatar,.messenger-message-avatar{display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#2a2200;background:#ffe500e6}.messenger-room-badge{width:46px;height:46px;border-radius:18px;font-size:.95rem}.messenger-main-avatar{width:54px;height:54px;border-radius:20px;font-size:1.05rem;flex-shrink:0}.messenger-main-avatar.placeholder{background:#ffffffd1;color:var(--gray-500)}.messenger-message-avatar{width:38px;height:38px;border-radius:14px;font-size:.82rem;flex-shrink:0}.messenger-room-body{min-width:0;display:grid;gap:6px}.messenger-room-head strong,.messenger-main-title-row h3,.messenger-search-item strong,.messenger-participant-item strong{color:var(--gray-900)}.messenger-room-head span,.messenger-room-snippet,.messenger-main-header p,.messenger-message-meta span,.messenger-message-foot span,.messenger-search-item span,.messenger-participant-item span,.messenger-participant-item small,.messenger-detail-header p,.messenger-drop-hint{color:var(--gray-500);font-size:var(--font-size-xs)}.messenger-room-snippet{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.messenger-room-unread{min-width:24px;height:24px;padding:0 8px;border-radius:999px;background:var(--messenger-yellow);color:#2a2200;font-size:11px;font-weight:800;display:inline-flex;align-items:center;justify-content:center}.messenger-main{min-height:720px;padding:16px;border:1px solid #acc1d4;border-radius:30px;background:linear-gradient(180deg,var(--messenger-chat-bg) 0%,var(--messenger-chat-bg-deep) 100%);display:flex;flex-direction:column;gap:12px}.messenger-main-header,.messenger-pin-banner,.messenger-search-panel,.messenger-composer{margin-bottom:0;padding:14px 16px;border-radius:22px;border:1px solid rgba(255,255,255,.58);background:#ffffffd1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.messenger-main-leading{align-items:center;min-width:0}.messenger-main-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.messenger-main-actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.messenger-pin-banner{display:flex;align-items:center;gap:12px}.messenger-pin-banner p,.messenger-search-item p{margin:0;white-space:pre-wrap;color:var(--gray-700)}.messenger-message-stream{flex:1;min-height:360px;overflow-y:auto;padding:6px 6px 6px 0;display:grid;gap:8px}.messenger-day-divider{display:flex;justify-content:center;margin:8px 0 4px}.messenger-day-divider span{padding:6px 12px;border-radius:999px;background:#ffffffb3;color:#506070;font-size:var(--font-size-xs);font-weight:700}.messenger-message-row{display:flex;align-items:flex-end;gap:10px}.messenger-message-row.mine{justify-content:flex-end}.messenger-message-row.system{justify-content:center}.messenger-message-row.highlighted .messenger-bubble,.messenger-message-row.highlighted .messenger-system-message{box-shadow:0 0 0 3px #ffe50080}.messenger-message-stack{max-width:min(72%,660px)}.messenger-message-row.mine .messenger-message-stack{align-items:flex-end}.messenger-message-meta{display:grid;gap:2px;padding:0 4px}.messenger-bubble{padding:11px 14px;border:1px solid rgba(17,24,39,.08);border-radius:22px;background:#fff;color:var(--gray-900);line-height:1.5;font-size:var(--font-size-sm)}.messenger-bubble.theirs{border-radius:8px 22px 22px}.messenger-bubble.mine{border-color:#edd00f;border-radius:22px 8px 22px 22px;background:var(--messenger-yellow);color:#231d00}.messenger-bubble-text{white-space:pre-wrap;word-break:break-word}.messenger-forward-chip{margin-bottom:10px;padding:7px 10px;border-radius:14px;background:#0f172a0f;font-size:var(--font-size-xs)}.messenger-system-message{padding:9px 14px;border-radius:999px;background:#ffffffbd;color:var(--gray-700);font-size:var(--font-size-sm)}.messenger-attachment-list,.messenger-emoji-grid,.messenger-participant-list,.messenger-check-list,.messenger-message-menu{display:grid;gap:10px}.messenger-selected-files{display:flex;flex-wrap:wrap;gap:8px}.messenger-selected-files span{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;background:#ffffffd1;border:1px solid rgba(255,255,255,.65);color:var(--gray-700);font-size:var(--font-size-xs)}.messenger-attachment-item,.messenger-search-item,.messenger-participant-item,.messenger-check-item{display:grid;gap:4px;padding:12px 14px;border:1px solid var(--messenger-border);border-radius:16px;background:#fff}.messenger-search-item{text-align:left;cursor:pointer}.messenger-participant-item{grid-template-columns:minmax(0,1fr) auto;align-items:center}.messenger-check-item{grid-template-columns:auto minmax(0,1fr);align-items:center}.messenger-check-item small{grid-column:2}.messenger-search-results{max-height:220px;overflow-y:auto}.messenger-message-foot{align-items:center;flex-wrap:wrap}.messenger-message-row.mine .messenger-message-foot{justify-content:flex-end}.messenger-shell .feed-action-button{padding:0;border:none;background:transparent;color:var(--gray-600);font-size:var(--font-size-xs);box-shadow:none}.messenger-message-menu button{border:1px solid var(--messenger-border);background:#fff;padding:10px 12px;border-radius:14px;cursor:pointer}.messenger-message-menu button.danger{color:var(--danger)}.messenger-composer{margin-top:0;border-top:none;gap:12px}.messenger-composer-tools{justify-content:space-between;align-items:center;flex-wrap:wrap}.messenger-composer-actions{display:flex;gap:8px;flex-wrap:wrap}.messenger-composer-row{align-items:flex-end}.messenger-composer-row .btn{min-width:86px;height:46px}.messenger-emoji-panel{padding:14px;border-radius:18px;border:1px solid var(--messenger-border);background:#fff;display:grid;gap:12px}.messenger-emoji-grid{grid-template-columns:repeat(6,minmax(0,1fr))}.messenger-emoji-grid button{border:none;border-radius:14px;background:#f8fafc;padding:12px;font-size:1.15rem;cursor:pointer}.messenger-detail-panel{position:fixed;top:24px;right:24px;bottom:24px;width:min(360px,calc(100vw - 32px));z-index:140;transform:translate(calc(100% + 24px));opacity:0;pointer-events:none;transition:transform .22s ease,opacity .22s ease}.messenger-detail-panel.open{transform:translate(0);opacity:1;pointer-events:auto}.messenger-detail-drawer{height:100%;display:flex;flex-direction:column;border:1px solid var(--messenger-border);border-radius:30px;background:#fff;box-shadow:0 28px 60px #0f172a2e;overflow:hidden}.messenger-detail-header{align-items:flex-start;padding:18px 20px;border-bottom:1px solid #eef2f6}.messenger-detail-content{padding:16px;overflow-y:auto}.messenger-detail-actions{flex-wrap:wrap}.messenger-detail-actions .btn{flex:1 1 120px}.messenger-modal{width:min(860px,calc(100vw - 32px))}.messenger-community-modal{width:min(1180px,calc(100vw - 32px))}.messenger-community-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:16px}.messenger-community-list-panel,.messenger-community-detail-panel{min-width:0}.max-grid{max-height:240px;overflow-y:auto}.messenger-mobile-only{display:none}@media(max-width:1280px){.messenger-layout{grid-template-columns:290px minmax(0,1fr)}}@media(max-width:1080px){.messenger-layout{grid-template-columns:1fr}.messenger-sidebar{position:fixed;top:16px;left:16px;bottom:16px;width:min(360px,calc(100vw - 32px));height:auto;min-height:0;max-height:none;transform:translate(calc(-100% - 20px));transition:transform .22s ease;z-index:140;box-shadow:0 28px 60px #0f172a2e}.messenger-sidebar.open{transform:translate(0)}.messenger-drawer-backdrop{display:block}.messenger-drawer-backdrop.visible{opacity:1;pointer-events:auto}.messenger-mobile-only{display:inline-flex}.messenger-page-header{align-items:flex-start;flex-direction:column}.messenger-main{min-height:calc(100vh - 220px)}.messenger-main-header{align-items:flex-start;flex-direction:column}.messenger-main-actions{justify-content:flex-start}.messenger-message-stack{max-width:min(82%,560px)}.messenger-detail-panel{top:16px;right:16px;bottom:16px}.messenger-community-layout{grid-template-columns:1fr}}@media(max-width:720px){.messenger-shell{gap:10px}.messenger-page-header h2{font-size:1.35rem}.messenger-main,.messenger-sidebar,.messenger-detail-drawer{border-radius:24px}.messenger-main,.messenger-sidebar-frame{padding:12px}.messenger-main-header,.messenger-pin-banner,.messenger-search-panel,.messenger-composer{padding:12px;border-radius:18px}.messenger-main-actions,.messenger-composer-row,.messenger-detail-actions{flex-direction:column;align-items:stretch}.messenger-main-actions .btn,.messenger-composer-row .btn,.messenger-detail-actions .btn{width:100%}.messenger-message-row{gap:8px}.messenger-message-stack{max-width:92%}.messenger-main-avatar{width:46px;height:46px;border-radius:16px}.messenger-emoji-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.messenger-sidebar{top:10px;left:10px;bottom:10px;width:calc(100vw - 20px)}.messenger-detail-panel{top:10px;right:10px;bottom:10px;width:calc(100vw - 20px)}}.proj-shell{display:grid;gap:10px;height:100%}.proj-page-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:4px}.proj-page-heading h2{margin:0;font-size:1.15rem}.proj-page-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.proj-toast{padding:8px 14px;border-radius:8px;font-size:13px;font-weight:500}.proj-toast-ok{background:#ecfdf5;border:1px solid #86efac;color:#166534}.proj-toast-err{background:#fef2f2;border:1px solid #fca5a5;color:#991b1b}.proj-status-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.proj-status-dot.badge-green{background:var(--success)}.proj-status-dot.badge-blue{background:var(--primary-500)}.proj-status-dot.badge-orange{background:var(--warning)}.proj-status-dot.badge-red{background:#ef4444}.proj-status-dot.badge-gray{background:var(--gray-400)}.proj-count-chip{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:var(--gray-100);color:var(--gray-600);font-size:11px;font-weight:700}.proj-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:6px}.proj-card{display:grid;gap:4px;padding:10px 12px;border:1px solid var(--gray-200);border-radius:10px;background:var(--card-bg);cursor:pointer;text-align:left;font:inherit;transition:border-color .12s ease,background .12s ease}.proj-card:hover{border-color:var(--gray-300);background:#fafbfc}.proj-card.active{border-color:var(--primary-300);background:var(--primary-50)}.proj-card-row1{display:flex;align-items:center;gap:6px}.proj-card-name{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.proj-type-pill{padding:1px 6px;border-radius:999px;background:var(--gray-100);color:var(--gray-500);font-size:10px;font-weight:600;flex-shrink:0}.proj-card-progress{display:flex;align-items:center;gap:6px}.proj-bar{flex:1;height:6px;background:var(--gray-100);border-radius:3px;overflow:hidden}.proj-bar-md{height:8px}.proj-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary-500),var(--primary-400));transition:width .3s ease}.proj-pct{font-size:11px;font-weight:600;color:var(--gray-600);min-width:24px;text-align:right}.proj-card-row3{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--gray-500)}.proj-card-pm{font-weight:500;color:var(--gray-700)}.proj-workspace{display:grid;grid-template-columns:2fr 1fr;gap:16px;align-items:start}.proj-detail,.proj-members{background:var(--card-bg);border:1px solid var(--gray-200);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:16px}.proj-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.proj-detail-head h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--gray-900);line-height:1.3}.proj-detail-head-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.proj-summary-strip{display:flex;flex-wrap:wrap;gap:20px;padding:12px 14px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.proj-summary-item{display:flex;flex-direction:column;gap:4px}.proj-summary-item small{font-size:11px;font-weight:600;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.proj-summary-item span{font-size:13px;font-weight:600;color:var(--gray-900)}.proj-summary-progress{display:flex;align-items:center;gap:8px;min-width:140px}.proj-summary-progress strong{font-size:13px;font-weight:700;color:var(--primary-600)}.proj-detail-body{display:grid;gap:16px}.proj-info-block{display:flex;flex-direction:column;gap:6px}.proj-info-label{font-size:12px;font-weight:600;color:var(--gray-500)}.proj-info-value{font-size:13px;color:var(--gray-800);line-height:1.5;white-space:pre-wrap}.proj-goal{font-size:14px;font-weight:500;color:var(--primary-900);background:var(--primary-50);padding:10px 12px;border-radius:6px;border-left:3px solid var(--primary-400)}.proj-meta-row{display:flex;gap:24px;padding-top:12px;border-top:1px dashed var(--gray-200)}.proj-meta-item{display:flex;flex-direction:column;gap:4px}.proj-meta-item small{font-size:11px;color:var(--gray-500)}.proj-meta-item span{font-size:13px;font-weight:500;color:var(--gray-800)}.proj-status-control{margin-top:8px;padding:12px;background:#fffcf0;border:1px solid #fef08a;border-radius:8px}.proj-status-select{max-width:200px;height:32px;font-size:13px}.proj-members-head{display:flex;justify-content:space-between;align-items:center}.proj-members-head h3{margin:0;font-size:1rem;font-weight:700}.proj-members-empty{padding:30px 0;text-align:center;font-size:13px;color:var(--gray-500)}.proj-members-list{display:grid;gap:8px}.proj-member{display:grid;grid-template-columns:auto 1fr auto;gap:10px;align-items:center;padding:8px 10px;border-radius:8px;background:#fff;border:1px solid var(--gray-200);transition:border-color .2s}.proj-member:hover{border-color:var(--gray-300)}.proj-member.pm{border-color:var(--primary-200);background:#f0fdf4}.proj-member-avatar{width:32px;height:32px;border-radius:50%;background:var(--gray-100);color:var(--gray-600);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}.proj-member.pm .proj-member-avatar{background:var(--success);color:#fff}.proj-member-info{display:flex;flex-direction:column;min-width:0}.proj-member-info strong{font-size:13px;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-member-info span{font-size:11px;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.proj-role-pill{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;background:var(--gray-100);color:var(--gray-600)}.proj-role-pill.pm{background:#dcfce7;color:#166534}.proj-kanban-toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;padding:12px 16px;background:var(--card-bg);border:1px solid var(--gray-200);border-radius:10px;margin-bottom:12px}.proj-kanban-select{display:flex;align-items:center;gap:12px;flex:1;min-width:260px}.proj-kanban-select label{margin:0;color:var(--gray-600);font-weight:600;font-size:13px;white-space:nowrap}.proj-kanban-select select{max-width:300px;height:34px;border-color:var(--gray-300)}.proj-kanban-actions{display:flex;align-items:center;gap:10px}.proj-kanban-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;min-height:500px;align-items:flex-start}.proj-kanban-col{flex:1;min-width:260px;max-width:320px;display:flex;flex-direction:column;background:#f4f5f7;border-radius:10px;border:1px solid var(--gray-200);overflow:hidden}.proj-kanban-col-head{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border-bottom:1px solid var(--gray-200);background:#fff}.proj-kanban-col-title{display:flex;align-items:center;gap:8px}.proj-col-bar{width:4px;height:16px;border-radius:2px;background:var(--col-accent, var(--gray-400))}.proj-kanban-col-head h4{margin:0;font-size:13px;font-weight:700;color:var(--gray-800)}.proj-kanban-col-body{padding:8px;display:flex;flex-direction:column;gap:8px;overflow-y:auto;max-height:600px}.proj-kanban-empty{padding:20px 0;text-align:center;font-size:12px;color:var(--gray-400);font-weight:500}.proj-task-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:10px;box-shadow:0 1px 2px #00000005;transition:transform .15s,box-shadow .15s}.proj-task-card:hover{transform:translateY(-1px);box-shadow:0 4px 6px #0000000a;border-color:var(--gray-300)}.proj-task-head{display:flex;align-items:flex-start;gap:6px;margin-bottom:6px}.proj-task-head strong{font-size:13px;font-weight:600;color:var(--gray-900);line-height:1.3;word-break:break-word}.proj-task-head .proj-status-dot{margin-top:4px}.proj-task-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--gray-500);margin-bottom:6px}.proj-task-desc{font-size:12px;color:var(--gray-600);background:#f8fafc;padding:6px 8px;border-radius:4px;border:1px solid #e2e8f0;margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.proj-task-foot{display:flex;flex-direction:column;gap:8px}.proj-task-status-select{height:26px;font-size:11px;padding:0 24px 0 8px;background-color:#f8fafc;border-color:var(--gray-200)}.proj-task-actions{display:flex;gap:6px;justify-content:flex-end}.proj-btn-danger{color:#dc2626!important;border-color:#fca5a5!important}.proj-btn-danger:hover{background:#fef2f2!important}.proj-modal{max-width:600px;width:100%}.proj-modal-body{padding:0;max-height:70vh;overflow-y:auto}.proj-modal-section{padding:20px;border-bottom:1px solid var(--gray-200);display:flex;flex-direction:column;gap:14px}.proj-modal-section:last-child{border-bottom:none}.proj-section-title{font-size:14px;font-weight:700;color:var(--primary-700);border-bottom:2px solid var(--primary-100);padding-bottom:6px;margin-bottom:4px}.proj-pm-display{display:flex;align-items:center;background:#f8fafc;font-weight:600;color:var(--gray-700)}.proj-no-users{padding:20px;text-align:center;color:var(--gray-500);font-size:13px;background:#f8fafc;border-radius:6px}.proj-member-checklist{display:flex;flex-direction:column;gap:2px}.proj-member-check-row{display:grid;grid-template-columns:auto 1fr 100px;gap:10px;align-items:center;padding:8px 10px;border-radius:6px;background:#fff;transition:background .1s}.proj-member-check-row:hover{background:#f8fafc}.proj-member-check-info{display:flex;flex-direction:column;min-width:0}.proj-member-check-info strong{font-size:13px;font-weight:600;color:var(--gray-900)}.proj-member-check-info span{font-size:11px;color:var(--gray-500)}.proj-role-select{height:28px;font-size:12px}.board-shell{display:grid;gap:16px;align-items:start}@media(min-width:1024px){.board-shell{grid-template-columns:220px minmax(0,1fr) 280px}}@media(max-width:1023px){.board-shell{grid-template-columns:1fr}}.board-sidebar-card{background:var(--card-bg);border:1px solid var(--gray-200);border-radius:10px;padding:14px;margin-bottom:12px}.board-sidebar-card h3{margin:0 0 10px;font-size:13px;font-weight:700;color:var(--gray-800)}.board-filter-stack{display:flex;flex-direction:column;gap:8px}.board-filter-stack .form-input{height:32px;font-size:13px;padding:0 10px}.board-main-toolbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f8fafc;border:1px solid var(--gray-200);border-radius:10px;margin-bottom:12px}.board-toolbar-actions{display:flex;gap:8px;flex-wrap:wrap}.board-toolbar-button{padding:4px 10px;border:1px solid transparent;background:transparent;color:var(--gray-600);font-size:13px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s}.board-toolbar-button:hover{background:var(--gray-100);color:var(--gray-900)}.board-toolbar-button.active{background:#fff;border-color:var(--gray-300);color:var(--primary-600);box-shadow:0 1px 2px #0000000d}.board-card-list{display:flex;flex-direction:column;gap:8px}.board-card{display:flex;flex-direction:column;gap:4px;padding:12px 16px;background:#fff;border:1px solid var(--gray-200);border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left}.board-card:hover{border-color:var(--gray-400);box-shadow:0 2px 4px #00000005}.board-card.pinned{background:#fffcf0;border-color:#fef08a}.board-card-row1{display:flex;align-items:center;gap:8px}.board-card-title{flex:1;font-size:14px;font-weight:600;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;line-height:1.4}.board-card-row2{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.board-card-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:var(--gray-500)}.board-card-author{display:flex;align-items:center;gap:6px;font-weight:500;color:var(--gray-700)}.board-card-stats{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--gray-400);font-weight:500}.board-card-stats span{display:flex;align-items:center;gap:3px}.board-summary-text{font-size:13px;color:var(--gray-600);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:2px 0 0}.board-badge{display:inline-flex;align-items:center;justify-content:center;height:20px;padding:0 6px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap;flex-shrink:0}.board-badge.blue{background:#eff6ff;color:#1d4ed8}.board-badge.gray{background:#f1f5f9;color:#475569}.board-badge.red{background:#fef2f2;color:#b91c1c}.board-badge.green{background:#f0fdf4;color:#15803d}.board-badge.orange{background:#fff7ed;color:#c2410c}.board-widget-card{background:#fff;border:1px solid var(--gray-200);border-radius:10px;overflow:hidden;margin-bottom:12px}.board-widget-header{padding:12px 14px;border-bottom:1px solid var(--gray-100);background:#f8fafc}.board-widget-header h3{margin:0;font-size:12px;font-weight:700;color:var(--gray-700)}.board-widget-list{display:flex;flex-direction:column}.board-widget-item{display:flex;flex-direction:column;gap:4px;padding:10px 14px;cursor:pointer;text-align:left;background:transparent;transition:background .15s;border-radius:0;border:none;border-bottom:1px solid var(--gray-100);width:100%;display:block}.board-widget-item:hover{background:#f8fafc}.board-widget-item:last-child{border-bottom:none}.board-widget-title{font-size:12px;font-weight:600;color:var(--gray-900);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;margin:0}.board-widget-meta{display:flex;justify-content:space-between;font-size:11px;color:var(--gray-500);margin-top:4px}.board-detail-header{padding-bottom:16px;border-bottom:1px solid var(--gray-200);margin-bottom:20px}.board-detail-title-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.board-detail-title{margin:0;font-size:1.4rem;font-weight:700;color:var(--gray-900);line-height:1.3;word-break:break-word}.board-detail-meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.board-detail-author-info{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--gray-600)}.board-detail-author-info strong{color:var(--gray-900);font-weight:600}.board-detail-actions{display:flex;align-items:center;gap:6px}.board-detail-content{font-size:15px;color:var(--gray-800);line-height:1.6;min-height:120px;padding-bottom:30px}.board-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;margin-bottom:16px}.board-box-title{font-size:13px;font-weight:700;color:var(--gray-800);margin:0 0 12px;border-bottom:1px solid var(--gray-200);padding-bottom:8px}.board-box-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:8px;font-size:13px}.board-box-row:last-child{margin-bottom:0}.board-box-label{font-weight:600;color:var(--gray-500);width:80px;flex-shrink:0}.board-box-value{color:var(--gray-900);flex:1;min-width:0}.board-comment-section{margin-top:30px;border-top:2px solid var(--gray-100);padding-top:20px}.board-comment-form{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;background:#f8fafc;padding:12px;border-radius:8px;border:1px solid var(--gray-200)}.board-comment-input{border:1px solid var(--gray-300);border-radius:6px;padding:10px;font-size:13px;resize:vertical;min-height:60px;font-family:inherit}.board-comment-input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-50)}.board-comment-controls{display:flex;justify-content:space-between;align-items:center}.board-comment-item{padding:12px 0;border-bottom:1px solid var(--gray-100)}.board-comment-item:last-child{border-bottom:none}.board-comment-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.board-comment-header strong{font-size:13px;color:var(--gray-900)}.board-comment-header small{font-size:11px;color:var(--gray-500)}.board-comment-body{font-size:13px;color:var(--gray-800);line-height:1.5;white-space:pre-wrap;margin:0 0 6px}.board-comment-actions{display:flex;gap:10px}.board-action-btn{padding:4px 8px;font-size:12px;font-weight:500;color:var(--gray-600);background:transparent;border:1px solid var(--gray-200);border-radius:4px;cursor:pointer;transition:all .2s}.board-action-btn:hover{background:var(--gray-50);border-color:var(--gray-300);color:var(--gray-900)}.board-action-btn.active{background:var(--primary-50);border-color:var(--primary-200);color:var(--primary-700)}.board-modal-section{padding:20px;border-bottom:1px solid var(--gray-200);display:flex;flex-direction:column;gap:14px}.board-modal-section:last-child{border-bottom:none}.board-section-title{font-size:14px;font-weight:700;color:var(--primary-700);border-bottom:2px solid var(--primary-100);padding-bottom:6px;margin-bottom:4px}.community-rail{flex:0 0 260px;position:sticky;top:calc(var(--header-height) + var(--spacing-lg));max-height:calc(100vh - var(--header-height) - var(--spacing-lg) * 2);overflow-y:auto}.community-nav-list{display:flex;flex-direction:column;gap:4px}.community-nav-item{display:flex;flex-direction:column;padding:8px 10px;border-radius:8px;background:transparent;border:1px solid transparent;text-align:left;transition:all .2s;cursor:pointer}.community-nav-item:hover{background:var(--bg-hover)}.community-nav-item.active{background:var(--bg-active);border-color:var(--border-color)}.community-nav-item strong{font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.community-nav-item span{font-size:.8rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.community-nav-meta{display:flex;align-items:center;gap:6px;margin-bottom:4px}.community-hero-compact{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border-color);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.community-hero-compact .community-cover-thumbnail{flex:0 0 80px;height:80px;border-radius:var(--radius-md);background:var(--bg-muted);overflow:hidden;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color)}.community-hero-compact .community-cover-thumbnail img{width:100%;height:100%;object-fit:cover}.community-hero-compact .community-hero-body{flex:1;min-width:0}.community-hero-compact h3{margin:0 0 4px;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.community-hero-compact p{margin:0 0 12px;font-size:.9rem;color:var(--text-secondary)}.community-action-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:12px}.community-activity-feed{display:flex;flex-direction:column;gap:8px}.community-feed-item{display:flex;align-items:flex-start;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;text-align:left}.community-feed-item:hover{border-color:var(--primary-light);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.community-feed-item-content{flex:1;min-width:0}.community-feed-item-top{display:flex;align-items:center;gap:8px;margin-bottom:4px}.community-feed-item strong{display:block;font-size:.95rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.community-feed-item p{margin:0;font-size:.85rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.community-feed-item-meta{display:flex;flex-direction:column;align-items:flex-end;margin-left:16px;font-size:.75rem;color:var(--text-muted);min-width:80px;text-align:right}.community-admin-panel .card-header{padding:12px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-muted)}.community-admin-panel .card-header h3{font-size:.9rem;margin:0;font-weight:600}.community-admin-panel .card-body{padding:12px 16px}.community-side-list{display:flex;flex-direction:column;gap:8px;font-size:.85rem}.community-side-list>div{display:flex;justify-content:space-between}.community-side-list strong{color:var(--text-secondary);font-weight:500}.community-admin-panel .community-member-list{display:flex;flex-direction:column;gap:6px}.community-member-item{display:flex;align-items:center;justify-content:space-between;padding:6px 8px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-card)}.community-member-item.operator{border-color:var(--primary-light);background:rgba(var(--primary-rgb),.05)}.community-member-item.operator strong{color:var(--primary)}.community-member-item>div:first-child{display:flex;flex-direction:column}.community-member-item strong{font-size:.85rem}.community-member-item span{font-size:.75rem;color:var(--text-secondary)}.community-member-actions{display:flex;gap:4px}.community-member-actions select{padding:2px 6px;font-size:.75rem;height:24px}.community-member-actions button{padding:2px 8px;font-size:.75rem;height:24px}.community-modal-shell{max-width:800px;width:100%;padding:0}.community-modal-shell .modal-body{padding:0!important}.community-modal-section{padding:var(--spacing-lg);border-bottom:1px solid var(--border-color)}.community-modal-section:last-child{border-bottom:none}.community-modal-section-header{margin-bottom:var(--spacing-md)}.community-modal-section-header h4{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.community-modal-section-header p{margin:4px 0 0;font-size:.85rem;color:var(--text-secondary)}.community-form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.form-span-2{grid-column:span 2}.community-empty-action{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:30px 20px;background:var(--bg-muted);border:2px dashed var(--border-color);border-radius:var(--radius-lg);text-align:center;color:var(--text-secondary)}.community-empty-action .empty-icon{font-size:2rem;margin-bottom:12px;color:var(--text-muted)}.community-empty-action h3{margin:0 0 8px;font-size:1.1rem;color:var(--text-primary)}.community-empty-action p{margin:0 0 16px;font-size:.9rem}
