:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#1a202c;background-color:#f7fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-base: #f7fafc;--bg-mantle: #edf2f7;--bg-crust: #e2e8f0;--text-primary: #1a202c;--text-secondary: #718096;--primary-color: #1a73e8;--secondary-color: #e91e8c;--success-color: #38a169;--warning-color: #d69e2e;--error-color: #e53e3e;--border-color: #e2e8f0;--card-bg: #ffffff;--hover-bg: #f0f4ff}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;min-width:320px;min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1e1e2e}::-webkit-scrollbar-thumb{background:#45475a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#585b70}.data-table-container{background:var(--card-bg, #363a4f);border-radius:8px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden;margin-top:1rem}.data-table{width:100%;border-collapse:collapse;font-size:.875rem;color:var(--text-primary, #cad3f5)}.data-table th{background-color:#0003;padding:1rem 1.5rem;text-align:left;font-weight:600;color:var(--text-secondary, #a5adcb);border-bottom:1px solid var(--border-color, #494d64);white-space:nowrap}.data-table td{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color, #494d64);vertical-align:middle}.data-table tr:hover{background-color:var(--hover-bg, #494d64)}.data-table tr:last-child td{border-bottom:none}.text-right{text-align:right}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500;background-color:#8aadf41a;color:var(--primary-color, #8aadf4);border:1px solid rgba(138,173,244,.2)}.btn-link{background:none;border:none;color:var(--primary-color, #8aadf4);cursor:pointer;padding:0;font-size:.875rem}.btn-link:hover{text-decoration:underline}.page-content{max-width:1200px;margin:0 auto;width:100%}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;border:1px solid currentColor;background-color:#ffffff1a;display:inline-block;font-weight:500}.sidebar{width:260px;height:100vh;background-color:#1e1e2e;color:#cdd6f4;display:flex;flex-direction:column;transition:width .3s ease;border-right:1px solid #313244}.sidebar.collapsed{width:72px}.sidebar-header{height:64px;display:flex;align-items:center;padding:0 24px;border-bottom:1px solid #313244}.sidebar.collapsed .sidebar-header{padding:0;justify-content:center}.logo-container{display:flex;align-items:center;gap:12px;font-weight:700;font-size:20px;color:#89b4fa}.logo-icon{width:24px;height:24px}.sidebar-nav{flex:1;padding:24px 12px;display:flex;flex-direction:column;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;border:none;background:transparent;color:#a6adc8;cursor:pointer;transition:all .2s;width:100%;text-align:left;font-size:14px}.sidebar.collapsed .nav-item{justify-content:center;padding:12px}.nav-item:hover{background-color:#313244;color:#fff}.nav-item.active{background-color:#89b4fa;color:#11111b;font-weight:600}.nav-icon{width:20px;height:20px}.sidebar-footer{padding:16px;border-top:1px solid #313244;background-color:#181825}.sidebar.collapsed .sidebar-footer{padding:16px 8px}.collapse-btn{width:100%;padding:8px;margin-bottom:16px;background:transparent;border:1px solid #45475a;border-radius:6px;color:#a6adc8;cursor:pointer;display:flex;justify-content:center;align-items:center}.collapse-btn:hover{background-color:#313244;color:#fff}.user-section{display:flex;align-items:center}.user-info{display:flex;align-items:center;gap:12px;width:100%}.sidebar.collapsed .user-info{justify-content:center}.avatar{width:36px;height:36px;border-radius:18px;background-color:#f5c2e7;color:#181825;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:4px;overflow:hidden}.user-name{font-size:14px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{display:flex;align-items:center;gap:6px;font-size:12px;color:#f38ba8;background:transparent;border:none;cursor:pointer;padding:0}.logout-btn:hover{text-decoration:underline}.app-layout{display:flex;width:100vw;height:100vh;overflow:hidden;background-color:#11111b}.main-content{flex:1;overflow-y:auto;padding:32px;background-color:#eff1f5;color:#4c4f69}@media(prefers-color-scheme:dark){.main-content{background-color:#181825;color:#cdd6f4}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100vw;background-color:#11111b;background-image:linear-gradient(135deg,#1e1e2e,#11111b);padding:40px 20px;box-sizing:border-box;overflow-y:auto}.login-card{width:100%;max-width:400px;background-color:#181825;border-radius:12px;box-shadow:0 4px 20px #0000004d;padding:40px;border:1px solid #313244}.login-header{text-align:center;margin-bottom:32px}.login-header h1{font-size:32px;font-weight:700;color:#89b4fa;margin-bottom:8px}.login-header p{color:#a6adc8;font-size:14px}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;color:#cdd6f4;font-weight:500}.input-with-icon{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:12px;color:#7f849c;pointer-events:none}.login-form .form-group input{flex:1;width:100%;padding:12px 40px 12px 12px;background-color:#1e1e2e;border:1px solid #45475a;border-radius:8px;color:#cdd6f4;font-size:15px;transition:all .2s}.password-toggle{position:absolute;right:10px;background:none;border:none;color:#7f849c;cursor:pointer;padding:4px;display:flex;align-items:center;transition:color .2s}.password-toggle:hover{color:#cdd6f4}.login-form .form-group .input-with-icon input{padding-left:48px}.login-form .form-group select{width:100%;padding:12px;background-color:#1e1e2e;border:1px solid #45475a;border-radius:8px;color:#cdd6f4;font-size:15px;transition:all .2s}.login-form .form-group select:focus{outline:none;border-color:#89b4fa;box-shadow:0 0 0 2px #89b4fa1a}.login-form .form-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.login-form .form-group input:focus{outline:none;border-color:#89b4fa;box-shadow:0 0 0 2px #89b4fa1a}.error-message{color:#f38ba8;font-size:14px;text-align:center;background-color:#f38ba81a;padding:8px;border-radius:6px}.submit-btn{background-color:#89b4fa;color:#1e1e2e;font-weight:600;padding:12px;border-radius:8px;border:none;cursor:pointer;font-size:16px;margin-top:8px;transition:background-color .2s;display:flex;justify-content:center;align-items:center}.submit-btn:hover{background-color:#b4befe}.submit-btn:disabled{opacity:.7;cursor:not-allowed}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.login-footer{margin-top:24px;text-align:center;font-size:12px;color:#585b70}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:#111827}.modal-close-btn{background:none;border:none;cursor:pointer;padding:4px;color:#6b7280;transition:color .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:#111827}.modal-body{padding:24px;overflow-y:auto;flex:1}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:#374151}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;transition:border-color .2s,box-shadow .2s;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group input.error,.form-group textarea.error{border-color:#ef4444}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.error-message{display:block;margin-top:6px;font-size:13px;color:#ef4444}.form-helper{display:block;margin-top:6px;font-size:12px;color:#64748b}.submit-error{margin-bottom:16px;padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{background:#93c5fd;cursor:not-allowed}.btn-secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#f3f4f6}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.dashboard-container{padding:32px;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-out}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.welcome-text{color:var(--text-secondary);font-size:15px}.create-btn{display:flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;border:none;padding:12px 24px;border-radius:12px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #6366f14d;transition:all .2s ease}.create-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:var(--card-bg);border-radius:20px;padding:24px;display:flex;align-items:center;gap:20px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.stat-icon{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.stat-card.blue .stat-icon{background:#eff6ff;color:#3b82f6}.stat-card.orange .stat-icon{background:#fff7ed;color:#f97316}.stat-card.purple .stat-icon{background:#f5f3ff;color:#8b5cf6}.stat-card.green .stat-icon{background:#ecfdf5;color:#10b981}.stat-info h3{font-size:14px;color:var(--text-secondary);margin:0 0 4px;font-weight:500}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.2;margin-bottom:4px}.stat-label{font-size:12px;color:var(--text-secondary);opacity:.8}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:24px}@media(max-width:1024px){.dashboard-content{grid-template-columns:1fr}}.section-card{background:var(--card-bg);border-radius:20px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);padding:24px;height:100%}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}.view-all-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--primary-color);font-size:13px;font-weight:500;cursor:pointer;transition:opacity .2s}.view-all-btn:hover{opacity:.8}.activity-list{display:flex;flex-direction:column;gap:12px}.activity-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border-radius:12px;background:var(--bg-color);transition:background .2s;cursor:pointer}.activity-item:hover{background:#f1f5f9}.activity-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.status-in_progress{background:#eff6ff;color:#3b82f6}.activity-icon.status-done{background:#ecfdf5;color:#10b981}.activity-icon.status-pending_review{background:#fff7ed;color:#f97316}.activity-icon.status-open{background:#f1f5f9;color:#64748b}.activity-details{flex:1;min-width:0}.activity-title{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{font-size:12px;color:var(--text-secondary)}.status-badge{padding:4px 10px;border-radius:8px;font-size:11px;font-weight:600;background:#f1f5f9;color:#64748b}.status-badge.status-in_progress{background:#eff6ff;color:#3b82f6}.status-badge.status-done{background:#ecfdf5;color:#10b981}.status-badge.status-pending_review{background:#fff7ed;color:#f97316}.empty-state{text-align:center;padding:40px 0;color:var(--text-secondary);font-size:14px}.leave-form{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.leave-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-secondary)}.leave-form input,.leave-form select,.leave-form textarea{border:1px solid var(--border-color);border-radius:10px;padding:10px 12px;font-size:14px;background:var(--bg-color);color:var(--text-primary)}.leave-submit-btn{width:100%;justify-content:center;margin-top:4px}.leave-list h4{margin:0 0 12px;font-size:14px;color:var(--text-secondary)}.leave-balance-panel{padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-color)}.leave-balance-title{font-size:13px;color:var(--text-secondary);margin-bottom:6px}.leave-balance-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;font-size:12px;color:var(--text-primary)}.leave-l0-tip{margin-top:6px;font-size:12px;color:#f97316}.leave-item{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;border:1px solid var(--border-color);background:var(--bg-color);margin-bottom:8px}.leave-review-item{align-items:center}.leave-item-main{display:flex;flex-direction:column;min-width:0}.leave-type{font-size:13px;font-weight:600;color:var(--text-primary)}.leave-time{font-size:12px;color:var(--text-secondary)}.leave-status{font-size:12px;border-radius:8px;padding:4px 8px;white-space:nowrap}.leave-status.leave-pending{color:#f97316;background:#fff7ed}.leave-status.leave-approved{color:#10b981;background:#ecfdf5}.leave-status.leave-rejected{color:#ef4444;background:#fef2f2}.leave-status.leave-cancelled{color:#64748b;background:#f1f5f9}.bug-image-trigger{border:1px solid #bfdbfe;background:#eff6ff;border-radius:8px;padding:4px 6px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:#1d4ed8}.bug-image-trigger:disabled{opacity:.7;cursor:default}.bug-image-trigger.compact{border-color:#dbe3ef;background:#fff;padding:2px}.bug-image-thumb{width:36px;height:36px;object-fit:cover;border-radius:6px;border:1px solid rgba(148,163,184,.45)}.bug-image-trigger.compact .bug-image-thumb{width:28px;height:28px}.bug-image-name{max-width:180px;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bug-image-placeholder{font-size:11px;color:#64748b}.bug-image-viewer{position:fixed;inset:0;background:#020617bf;z-index:1600;display:flex;align-items:center;justify-content:center;padding:20px}.bug-image-viewer-panel{width:min(1100px,100%);max-height:92vh;background:#0f172a;border:1px solid rgba(148,163,184,.3);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.bug-image-toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;color:#e2e8f0;background:#0f172ae6;border-bottom:1px solid rgba(148,163,184,.2)}.bug-image-toolbar strong{font-size:13px;font-weight:600}.bug-image-toolbar-actions{display:inline-flex;align-items:center;gap:6px}.bug-image-toolbar-actions button{border:1px solid rgba(148,163,184,.35);background:#1e293be6;color:#e2e8f0;border-radius:7px;padding:4px 8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.bug-image-toolbar-actions span{min-width:44px;text-align:center;font-size:12px;color:#cbd5e1}.bug-image-stage{flex:1;overflow:auto;padding:16px;background:#020617;display:flex;align-items:flex-start;justify-content:center}.bug-image-full{max-width:100%;max-height:calc(92vh - 72px);transform-origin:top center}.todo-image-trigger{border:1px solid #dbe3ef;background:#fff;border-radius:8px;width:72px;height:72px;padding:3px;cursor:pointer}.todo-image-thumb{width:100%;height:100%;object-fit:cover;border-radius:6px}.todo-image-viewer{position:fixed;inset:0;background:#020617c7;z-index:1700;display:flex;align-items:center;justify-content:center;padding:20px}.todo-image-viewer-panel{width:min(1100px,100%);max-height:92vh;background:#0f172a;border-radius:12px;overflow:hidden;border:1px solid rgba(148,163,184,.3);display:flex;flex-direction:column}.todo-image-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;color:#e2e8f0;border-bottom:1px solid rgba(148,163,184,.25)}.todo-image-actions{display:inline-flex;align-items:center;gap:6px}.todo-image-actions button{border:1px solid rgba(148,163,184,.35);background:#1e293be6;color:#e2e8f0;border-radius:7px;padding:4px 8px;cursor:pointer}.todo-image-actions span{min-width:44px;text-align:center;font-size:12px;color:#cbd5e1}.todo-image-stage{flex:1;overflow:auto;padding:16px;background:#020617;display:flex;justify-content:center}.todo-image-full{max-width:100%;max-height:calc(92vh - 72px);transform-origin:top center}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.detail-modal-content{background:var(--card-bg, #ffffff);border-radius:24px;width:90%;max-width:650px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;transform-origin:center;animation:modalPop .3s cubic-bezier(.16,1,.3,1);overflow:hidden}@keyframes modalPop{0%{transform:scale(.95) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.modal-header{padding:24px 32px;border-bottom:1px solid var(--border-color, #e2e8f0);display:flex;justify-content:space-between;align-items:center;background:var(--bg-color, #f8fafc)}.modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--text-secondary, #64748b)}.modal-close-btn{background:transparent;border:none;color:var(--text-secondary, #64748b);cursor:pointer;padding:8px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{background:#0000000d;color:var(--text-primary, #1e293b)}.detail-modal-body{padding:32px;overflow-y:auto;flex:1}.detail-title{font-size:28px;font-weight:700;color:var(--text-primary, #1e293b);line-height:1.2;margin-bottom:16px;letter-spacing:-.02em}.detail-badges{display:flex;flex-wrap:wrap;gap:10px}.detail-section{margin-bottom:32px}.detail-section h4{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary, #94a3b8);font-weight:700;margin-bottom:16px}.detail-description{font-size:16px;line-height:1.7;color:var(--text-primary, #334155);white-space:pre-wrap;background:var(--bg-color, #f8fafc);padding:20px;border-radius:12px;border:1px solid var(--border-color, #e2e8f0)}.todo-image-gallery{display:flex;flex-wrap:wrap;gap:10px}.todo-image-item{display:inline-flex;flex-direction:column;gap:6px;align-items:stretch}.todo-image-remove{border:1px solid #fecaca;color:#b91c1c;background:#fff5f5;border-radius:6px;font-size:12px;padding:3px 0;cursor:pointer}.todo-image-upload{width:72px;height:72px;border:1px dashed var(--border-color, #cbd5e1);border-radius:8px;background:var(--bg-color, #f8fafc);color:var(--text-secondary, #64748b);font-size:12px;font-weight:600;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;text-align:center;padding:4px}.todo-image-upload input{display:none}.detail-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.info-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--bg-color, #f8fafc);border-radius:12px;border:1px solid transparent;transition:all .2s}.info-item:hover{border-color:var(--border-color, #e2e8f0);transform:translateY(-1px)}.info-item svg{color:var(--primary-color, #6366f1)}.info-label{font-size:12px;color:var(--text-secondary, #64748b);margin-bottom:4px}.info-value{font-size:14px;font-weight:600;color:var(--text-primary, #1e293b)}.review-comment-section{background:#fffbeb;border:1px solid #fcd34d;border-radius:12px;padding:20px}.review-comment{color:#92400e;font-size:15px;margin:0}.pending-notice{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;padding:16px;border-radius:12px;color:#92400e;font-weight:600;display:flex;align-items:center;gap:12px}.detail-modal-footer{padding:24px 32px;background:var(--bg-color, #f8fafc);border-top:1px solid var(--border-color, #e2e8f0);display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}button{font-family:inherit}.btn-primary,.btn-secondary,.btn-success,.btn-warning,.btn-danger{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;border:1px solid transparent;display:flex;align-items:center;gap:8px}.btn-primary{background:var(--primary-color, #6366f1);color:#fff;box-shadow:0 4px 12px #6366f140}.btn-primary:hover{background:var(--primary-hover, #4f46e5);transform:translateY(-1px)}.btn-secondary{background:#fff;border-color:var(--border-color, #e2e8f0);color:var(--text-primary, #1e293b)}.btn-secondary:hover{background:var(--bg-color, #f8fafc);border-color:var(--text-secondary, #94a3b8)}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover{background:#dc2626}@media(prefers-color-scheme:dark){.detail-modal-content{background:#1e293b}.modal-header,.detail-modal-footer,.info-item,.detail-description{background:#0f172a;border-color:#334155}.detail-title,.info-value,.btn-secondary{color:#f1f5f9}.btn-secondary{background:#1e293b;border-color:#334155}.btn-secondary:hover{background:#334155}}:root{--primary-color: #6366f1;--primary-hover: #4f46e5;--bg-color: #f8fafc;--card-bg: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}@media(prefers-color-scheme:dark){:root{--primary-color: #818cf8;--primary-hover: #6366f1;--bg-color: #0f172a;--card-bg: #1e293b;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--border-color: #334155}}.todo-container{max-width:1400px;margin:0 auto;padding:32px 24px;font-family:Inter,system-ui,-apple-system,sans-serif;color:var(--text-primary)}.todo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.todo-header h1{font-size:32px;font-weight:700;letter-spacing:-.025em;color:var(--text-primary);background:linear-gradient(135deg,var(--text-primary) 0%,var(--text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.create-todo-btn{background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));color:#fff;border:none;padding:12px 20px;border-radius:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;box-shadow:0 4px 12px #6366f14d;transition:all .2s ease}.create-todo-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f166}.create-todo-btn:active{transform:translateY(0)}.todo-view-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--card-bg);padding:6px;border-radius:16px;border:1px solid var(--border-color);width:fit-content;box-shadow:var(--shadow-sm)}.view-tab{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;border:none;background:transparent;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.view-tab.active{background:var(--bg-color);color:var(--primary-color);box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.view-tab:hover:not(.active){color:var(--text-primary);background:#00000008}.todo-filters{display:flex;gap:12px;margin-bottom:32px;padding:10px;border:1px solid var(--border-color);border-radius:14px;background:var(--card-bg);box-shadow:var(--shadow-sm);align-items:center;flex-wrap:wrap}.filter-btn{background:var(--card-bg);color:var(--text-secondary);border:1px solid var(--border-color);padding:8px 16px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap;display:flex;align-items:center;gap:6px}.filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.filter-btn.active{background:var(--primary-color);color:#fff;border-color:var(--primary-color);box-shadow:0 2px 8px #6366f140}.filter-select-group{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}.filter-select-item{display:inline-flex;align-items:center;gap:8px;padding:4px 10px;border:1px solid var(--border-color);border-radius:999px;background:var(--bg-color);color:var(--text-secondary);font-size:12px;font-weight:600}.filter-select{border:none;outline:none;background:transparent;color:var(--text-primary);font-size:13px;font-weight:500;min-width:130px;cursor:pointer;padding-right:4px}.filter-select:focus{color:var(--primary-color)}@media(max-width:900px){.todo-filters{gap:10px;border-radius:12px}.filter-btn{padding:7px 12px}.filter-select-group{margin-left:0;width:100%}.filter-select-item{flex:1;min-width:0;justify-content:space-between}.filter-select{min-width:0;width:100%}}.todo-board{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;height:calc(100vh - 250px);min-height:500px;overflow-x:auto;padding-bottom:24px}.board-column{background:#f1f5f980;border-radius:16px;border:1px solid var(--border-color);display:flex;flex-direction:column;height:100%;min-width:280px}@media(prefers-color-scheme:dark){.board-column{background:#1e293b80}}.column-header{padding:16px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border-color);background:var(--card-bg);border-radius:16px 16px 0 0}.column-header h3{font-size:14px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.status-open{background:#94a3b8}.status-dot.status-in_progress{background:#3b82f6}.status-dot.status-pending_review{background:#f59e0b}.status-dot.status-done{background:#10b981}.count-badge{background:var(--bg-color);padding:2px 8px;border-radius:10px;font-size:12px;color:var(--text-secondary);border:1px solid var(--border-color)}.column-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.todo-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:16px;cursor:pointer;transition:all .2s cubic-bezier(.2,0,0,1);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:12px}.todo-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary-color)}.todo-card.dragging{opacity:.5;border:2px dashed var(--primary-color);box-shadow:none;cursor:grabbing}.board-column{transition:background .2s}.board-column:hover{background:#f1f5f9cc;border-color:var(--primary-color)}.todo-card.done{opacity:.7;background:var(--bg-color)}.card-header{display:flex;justify-content:space-between;align-items:center}.card-title{font-size:14px;font-weight:500;color:var(--text-primary);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:auto}.due-date{font-size:11px;color:var(--text-secondary);font-weight:500}.avatar-circle{width:24px;height:24px;border-radius:50%;background:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;border:2px solid var(--card-bg)}.todo-list{display:grid;gap:16px}.todo-item{background:var(--card-bg);border-radius:16px;padding:20px;display:flex;align-items:center;gap:20px;border:1px solid var(--border-color);transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;cursor:pointer}.todo-item:hover{transform:translateY(-2px) scale(1.005);box-shadow:var(--shadow-lg);border-color:var(--primary-hover)}.todo-checkbox{width:28px;height:28px;border-radius:8px;border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.todo-item:hover .todo-checkbox{border-color:var(--primary-color)}.todo-checkbox.checked{background:#10b981;border-color:#10b981;color:#fff}.todo-content{flex:1;min-width:0}.todo-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:8px;transition:color .2s}.todo-item.done .todo-title{text-decoration:line-through;color:var(--text-secondary)}.todo-meta{display:flex;gap:16px;font-size:12px;color:var(--text-secondary);align-items:center}.meta-tag{display:flex;align-items:center;gap:6px;background:var(--bg-color);padding:4px 8px;border-radius:6px}.priority-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.priority-p0{background:#fee2e2;color:#ef4444}.priority-p1{background:#ffedd5;color:#f97316}.priority-p2{background:#fef9c3;color:#eab308}.priority-p3{background:#dbeafe;color:#3b82f6}.status-mini{padding:4px 10px;border-radius:12px;font-size:11px;font-weight:500;display:flex;align-items:center;gap:4px}.status-mini:before{content:"";display:block;width:6px;height:6px;border-radius:50%}.status-open:before{background:#94a3b8}.status-in_progress:before{background:#3b82f6}.status-pending_review:before{background:#f59e0b}.status-done:before{background:#10b981}.status-mini.status-open{background:#f1f5f9;color:#64748b}.status-mini.status-in_progress{background:#eff6ff;color:#2563eb}.status-mini.status-pending_review{background:#fffbeb;color:#d97706}.status-mini.status-done{background:#ecfdf5;color:#059669}.empty-state{text-align:center;padding:80px 0;color:var(--text-secondary);background:var(--card-bg);border-radius:24px;border:1px dashed var(--border-color)}.notification{position:fixed;top:32px;right:32px;padding:16px 24px;border-radius:16px;font-weight:500;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:var(--shadow-lg);z-index:2000;animation:slideIn .4s cubic-bezier(.16,1,.3,1);border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;gap:12px}@keyframes slideIn{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.notification-success{background:#10b981e6;color:#fff}.notification-error{background:#ef4444e6;color:#fff}.finance-layout{display:flex;flex-direction:column;height:100%}.finance-header{padding:1.5rem 2rem;background-color:var(--card-bg);border-bottom:1px solid var(--border-color);display:flex;flex-direction:column;gap:1rem}.finance-header h1{margin:0;font-size:1.5rem;font-weight:600}.finance-nav{display:flex;gap:2rem}.finance-nav a{text-decoration:none;color:var(--text-secondary);font-weight:500;padding-bottom:.5rem;border-bottom:2px solid transparent;transition:all .2s}.finance-nav a:hover{color:var(--text-primary)}.finance-nav a.active{color:var(--primary-color);border-bottom-color:var(--primary-color)}.finance-content{flex:1;padding:2rem;overflow-y:auto}.modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-container{background-color:#fff;border:1px solid #e2e8f0;border-radius:12px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:#1a202c}.modal-close-btn{background:transparent;border:none;color:#718096;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close-btn:hover{background-color:#f0f4ff;color:#1a202c}.base-modal-content{padding:1.5rem;overflow-y:auto;color:#1a202c}.modal-footer{padding:1rem 1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:flex-end;gap:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#4a5568}.form-input,.form-select{width:100%;padding:.6rem .8rem;background-color:#fff;border:1px solid #e2e8f0;border-radius:6px;color:#1a202c;font-size:.95rem;transition:all .2s}.form-input:focus,.form-select:focus{outline:none;border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e826}.btn{padding:.6rem 1.2rem;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s;border:1px solid transparent;font-family:inherit}.btn-primary{background-color:#1a73e8;color:#fff}.btn-primary:hover{background-color:#1557b0}.btn-secondary{background-color:transparent;border-color:#e2e8f0;color:#4a5568}.btn-secondary:hover{background-color:#f7fafc}.finance-transaction-modal .form-input,.finance-transaction-modal .form-select{background-color:#fff;color:#0f172a;border:1px solid #cbd5e1}.finance-transaction-modal .form-input::placeholder{color:#64748b}.finance-transaction-modal .form-input:focus,.finance-transaction-modal .form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.finance-transaction-modal input[type=file].form-input{padding:.45rem .6rem}.iam-page{padding:0;position:relative}.iam-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.iam-page-header h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.iam-loading{text-align:center;padding:3rem;color:var(--text-secondary)}.iam-empty{text-align:center;padding:3rem;color:var(--text-secondary);background:var(--card-bg);border-radius:8px;border:1px dashed var(--border-color)}.iam-notification{position:fixed;top:20px;right:20px;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;z-index:9999;animation:slideIn .2s ease}.iam-notification.success{background:#a6da9526;color:var(--success-color);border:1px solid rgba(166,218,149,.3)}.iam-notification.error{background:#ed879626;color:var(--error-color);border:1px solid rgba(237,135,150,.3)}@keyframes slideIn{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.iam-search{display:flex;align-items:center;gap:8px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:8px 12px;color:var(--text-secondary)}.iam-search input{background:none;border:none;outline:none;color:var(--text-primary);font-size:14px;width:200px}.iam-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.iam-modal{background:#fff;border:1px solid #dbe3ee;border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0f172a40;color:#0f172a}.iam-modal-lg{max-width:640px}.iam-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e2e8f0}.iam-modal-header h3{font-size:16px;font-weight:600;color:#0f172a;margin:0}.iam-modal-header button{background:none;border:none;color:#64748b;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .2s}.iam-modal-header button:hover{color:#0f172a}.iam-modal-body{padding:24px;display:flex;flex-direction:column;gap:16px}.iam-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding-top:8px}.iam-form-group{display:flex;flex-direction:column;gap:6px;flex:1}.iam-form-group label{font-size:13px;font-weight:500;color:#334155}.iam-form-group input,.iam-form-group select,.iam-form-group textarea{background:#fff;border:1px solid #cbd5e1;border-radius:8px;padding:10px 12px;color:#0f172a;font-size:14px;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box}.iam-form-group input:focus,.iam-form-group select:focus{border-color:#3b82f6}.iam-form-group select option{background:#fff;color:#0f172a}.iam-form-row{display:flex;gap:16px}.iam-hint{font-size:12px;color:var(--text-secondary);opacity:.7}.iam-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--text-primary);flex-direction:row!important}.iam-checkbox-label input[type=checkbox]{width:auto;margin:0}.dept-tree{background:var(--card-bg);border-radius:8px;border:1px solid var(--border-color);overflow:hidden}.dept-node{border-bottom:1px solid var(--border-color)}.dept-node:last-child{border-bottom:none}.dept-row{display:flex;align-items:center;gap:8px;padding:12px 16px;transition:background .15s}.dept-row:hover{background:var(--hover-bg)}.dept-expand-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:2px;display:flex;align-items:center;border-radius:4px}.dept-name{font-weight:500;color:var(--text-primary);flex:1}.dept-desc{font-size:13px;color:var(--text-secondary)}.dept-member-count{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-secondary);background:var(--hover-bg);padding:2px 8px;border-radius:12px}.dept-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.dept-row:hover .dept-actions{opacity:1}.icon-action-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .15s,background .15s}.icon-action-btn:hover{color:var(--primary-color);background:#8aadf41a}.icon-action-btn.danger:hover{color:var(--error-color);background:#ed87961a}.org-chart{padding:16px 0}.org-node-wrapper{position:relative}.org-node{position:relative;display:flex;align-items:center;margin-bottom:8px}.org-connector{position:absolute;left:-16px;top:50%;width:16px;height:1px;background:var(--border-color)}.org-card{display:flex;align-items:center;gap:12px;background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:12px 16px;min-width:220px;transition:border-color .2s,box-shadow .2s}.org-card:hover{border-color:var(--primary-color);box-shadow:0 0 0 2px #8aadf41a}.org-card.shareholder{border-color:var(--warning-color);background:#eed49f0d}.org-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--bg-base);position:relative;flex-shrink:0}.org-crown{position:absolute;top:-6px;right:-4px;color:var(--warning-color);background:var(--bg-mantle);border-radius:50%;padding:1px}.org-info{flex:1;min-width:0}.org-name{font-weight:600;color:var(--text-primary);font-size:14px}.org-title{font-size:12px;color:var(--primary-color);margin-top:2px}.org-dept{font-size:11px;color:var(--text-secondary);margin-top:1px}.org-expand-btn{background:none;border:1px solid var(--border-color);border-radius:12px;color:var(--text-secondary);cursor:pointer;padding:2px 8px;display:flex;align-items:center;gap:4px;font-size:12px;transition:all .15s}.org-expand-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.org-level-badge{font-size:11px;font-weight:700;color:var(--text-secondary);background:var(--hover-bg);border:1px solid var(--border-color);border-radius:10px;padding:2px 7px;flex-shrink:0}.org-children{margin-left:32px;border-left:1px dashed var(--border-color);padding-left:0}.org-legend{display:flex;gap:16px;align-items:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}.legend-item.shareholder{color:var(--warning-color)}.btn-primary{display:flex;align-items:center;gap:6px;background:var(--primary-color);color:var(--bg-base);border:none;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-primary:hover{opacity:.85}.btn-secondary{background:var(--card-bg);color:var(--text-primary);border:1px solid var(--border-color);border-radius:8px;padding:10px 16px;font-size:14px;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:var(--hover-bg)}.project-list-container{padding:2rem;max-width:1400px;margin:0 auto;animation:fadeIn .4s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.project-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.project-header h1{font-size:2rem;font-weight:700;color:#1a1a2e;margin:0;letter-spacing:-.5px}.create-btn-wrapper{position:relative}.project-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #edf2f7;padding-bottom:0}.tab-btn{background:none;border:none;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#718096;cursor:pointer;position:relative;transition:all .2s ease;border-radius:8px 8px 0 0}.tab-btn:hover{color:#2b6cb0;background:#4299e10d}.tab-btn.active{color:#2b6cb0}.tab-btn.active:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:3px;background:#4299e1;border-radius:3px 3px 0 0}.tab-count{margin-left:8px;background:#edf2f7;color:#4a5568;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:700}.tab-btn.active .tab-count{background:#ebf8ff;color:#2b6cb0}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}.project-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;display:flex;flex-direction:column;justify-content:space-between;cursor:pointer;overflow:hidden}.project-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,#4299e1,#667eea);opacity:0;transition:opacity .3s ease}.project-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#cbd5e0}.project-card:hover:before{opacity:1}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.project-no{font-size:.8rem;font-family:JetBrains Mono,Courier New,monospace;color:#a0aec0;font-weight:600;letter-spacing:.5px}.project-status{padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.status-active,.status-in_progress{background:#c6f6d5;color:#22543d}.status-draft,.status-not_started{background:#edf2f7;color:#4a5568}.status-paused,.status-blocked{background:#feebc8;color:#7b341e}.status-closed,.status-done{background:#e2e8f0;color:#2d3748}.status-cancelled,.status-skipped{background:#fed7d7;color:#822727}.project-title{font-size:1.25rem;font-weight:700;color:#2d3748;margin:0 0 .5rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-meta{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;font-size:.85rem;color:#718096}.meta-item{display:flex;align-items:center;gap:.4rem}.meta-icon{color:#a0aec0}.project-progress-container{margin-top:auto;padding-top:1rem;border-top:1px solid #f2f4f8}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;font-weight:600;color:#4a5568}.progress-bar-bg{width:100%;height:8px;background-color:#edf2f7;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4299e1,#3182ce);border-radius:4px;transition:width .8s cubic-bezier(.4,0,.2,1)}.progress-bar-fill.complete{background:linear-gradient(90deg,#48bb78,#38a169)}.card-actions{position:absolute;bottom:1.5rem;right:1.5rem;opacity:0;transform:translate(10px);transition:all .3s ease}.project-card:hover .card-actions{opacity:1;transform:translate(0)}.btn-delete-icon{background:#fff;border:1px solid #fed7d7;color:#e53e3e;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.project-detail-page{max-width:min(1600px,calc(100vw - 48px))}.project-detail-grid{display:grid;grid-template-columns:minmax(0,3fr) minmax(280px,1fr);gap:1.5rem}.stage-card{overflow:hidden}.stage-table-scroll{overflow-x:auto;border:1px solid #e2e8f0;border-radius:10px}.stage-table{min-width:1080px}.stage-table td,.stage-table th{padding:.75rem .9rem}.stage-table .col-seq{width:52px}.stage-table .col-name{min-width:120px}.stage-table .col-status{min-width:150px}.stage-table .col-date{min-width:160px}.stage-table .col-note{min-width:260px}.stage-table .col-action{min-width:280px}.stage-action-wrap{flex-wrap:wrap;row-gap:8px}@media(max-width:1200px){.project-detail-page{max-width:calc(100vw - 24px)}.project-detail-grid{grid-template-columns:1fr}}.stage-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.stage-modal-container{background-color:#fff;border-radius:8px;width:600px;max-width:90vw;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column}.stage-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e2e8f0}.stage-modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.stage-modal-body{padding:1.5rem}.stage-modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-control{width:100%;padding:.5rem;border:1px solid #cbd5e1;border-radius:4px}.form-control:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.typing-indicator{display:flex;align-items:center;justify-content:center;gap:4px;padding:4px 8px}.typing-indicator span{width:6px;height:6px;background-color:#94a3b8;border-radius:50%;animation:typing 1s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.attachment-dropzone{box-sizing:border-box;width:100%;border:2px dashed var(--border-color, #e2e8f0);border-radius:12px;padding:30px;text-align:center;background-color:var(--bg-hover, #f8fafc);transition:all .2s ease;cursor:pointer;margin-bottom:24px;position:relative;overflow:hidden}.attachment-dropzone:hover,.attachment-dropzone.dragging{border-color:var(--primary-color, #3b82f6);background-color:var(--primary-lighter, #eff6ff)}.attachment-dropzone.dragging *{pointer-events:none}.attachment-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-color, #1e293b)}.attachment-dropzone-icon{color:var(--primary-color, #3b82f6);background:var(--bg-hover, #f1f5f9);padding:12px;border-radius:50%;transition:transform .2s ease}.attachment-dropzone:hover .attachment-dropzone-icon,.attachment-dropzone.dragging .attachment-dropzone-icon{transform:scale(1.1)}.attachment-dropzone-title{font-weight:500;font-size:1.05rem}.attachment-dropzone-subtitle{font-size:.85rem;color:var(--text-muted, #64748b)}.attachment-list{box-sizing:border-box;width:100%;list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}.attachment-item{box-sizing:border-box;width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border:1px solid var(--border-color, #e2e8f0);border-radius:10px;background-color:var(--bg-color, #ffffff);transition:all .2s ease;box-shadow:0 1px 3px #00000005}.attachment-item:hover{border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;transform:translateY(-1px)}.attachment-info{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.attachment-icon-wrapper{background:var(--bg-hover, #f8fafc);color:var(--primary-color, #3b82f6);padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center}.attachment-details{display:flex;flex-direction:column;gap:4px;min-width:0}.attachment-name{font-weight:500;font-size:.95rem;color:var(--text-color, #1e293b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;cursor:pointer;padding:0;text-align:left;transition:color .1s ease}.attachment-name:-webkit-any-link{text-decoration:none}.attachment-name:hover{color:var(--primary-color, #3b82f6)}.attachment-meta{display:flex;align-items:center;gap:12px;font-size:.8rem;color:var(--text-muted, #64748b)}.attachment-actions{display:flex;align-items:center;gap:8px;opacity:.6;transition:opacity .2s ease}.attachment-item:hover .attachment-actions{opacity:1}.attachment-action-btn{background:transparent;border:none;color:var(--text-muted, #64748b);padding:6px;border-radius:6px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.attachment-action-btn:hover{background-color:var(--bg-hover, #f1f5f9);color:var(--text-color, #1e293b)}.attachment-action-btn.danger:hover{background-color:var(--danger-lighter, #fef2f2);color:var(--danger-color, #ef4444)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-muted, #64748b);text-align:center;background:var(--bg-hover, #f8fafc);border-radius:12px;border:1px dashed var(--border-color, #e2e8f0)}.empty-state-icon{margin-bottom:12px;opacity:.5}.bug-detail-overlay{position:fixed;inset:0;z-index:1200;background:#0206179e;display:flex;align-items:center;justify-content:center;padding:20px}.bug-detail-modal{width:min(1020px,100%);max-height:90vh;border-radius:14px;overflow:hidden;background:#fff;border:1px solid #dbe3ef;box-shadow:0 20px 60px #02061759;display:flex;flex-direction:column}.bug-detail-header{padding:14px 16px;background:linear-gradient(120deg,#0f172a,#1e3a8a,#0ea5e9);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.bug-detail-header p{margin:0;font-size:12px;opacity:.9}.bug-detail-header h3{margin:4px 0 0;font-size:17px}.bug-detail-header-right{display:inline-flex;align-items:center;gap:8px}.bug-detail-header-right span{padding:3px 9px;border-radius:999px;font-size:12px;background:#ffffff2e;border:1px solid rgba(255,255,255,.35)}.bug-detail-header-right button{border:1px solid rgba(255,255,255,.4);border-radius:8px;background:transparent;color:#fff;cursor:pointer;width:32px;height:28px;display:inline-flex;align-items:center;justify-content:center}.bug-detail-body{padding:14px 16px;max-height:calc(90vh - 86px);overflow:auto}.bug-detail-grid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}.bug-detail-card{border:1px solid #e2e8f0;border-radius:10px;padding:10px;background:#f8fafc}.bug-detail-card div{font-size:12px;color:#64748b;margin-bottom:4px}.bug-detail-card strong{font-size:13px;color:#0f172a;word-break:break-word}.bug-detail-two-col{margin-top:14px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(290px,1fr))}.bug-detail-block{margin-top:14px;border:1px solid #e2e8f0;border-radius:10px;padding:10px;background:#fff}.bug-detail-block h4{margin:0 0 6px;font-size:13px;color:#0f172a}.bug-detail-block pre{margin:0;font-size:13px;color:#334155;white-space:pre-wrap;word-break:break-word;font-family:inherit;line-height:1.5}.bug-detail-extra-grid{display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.bug-detail-extra-item{border:1px dashed #dbe3ef;border-radius:8px;padding:8px;background:#f8fafc}.bug-detail-extra-item div{font-size:12px;color:#64748b;margin-bottom:4px}.bug-detail-images{display:flex;flex-wrap:wrap;gap:8px}.dev-progress-page{--ink: #0f172a;--muted: #64748b;--line: #dbe3ef;--panel: #ffffff;--brand: #0ea5e9}.dev-progress-toolbar{display:flex;justify-content:space-between;margin-bottom:12px}.dev-progress-actions{display:inline-flex;gap:8px}.dev-progress-back,.dev-progress-refresh{border:1px solid var(--line);background:var(--panel);border-radius:10px;padding:0 12px;height:36px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;color:var(--ink)}.dev-progress-primary{border:1px solid #0f172a;background:#0f172a;color:#fff;border-radius:10px;padding:0 12px;height:36px;display:inline-flex;align-items:center;gap:6px;cursor:pointer}.dev-progress-refresh:disabled,.dev-progress-primary:disabled{opacity:.5;cursor:not-allowed}.dev-progress-hero{border-radius:16px;padding:20px 22px;color:#fff;display:grid;grid-template-columns:1.7fr 1fr;gap:16px;background:linear-gradient(130deg,#0b1d3a,#0369a1)}.dev-progress-kicker{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.12em;opacity:.72}.dev-progress-hero h1{margin:6px 0 8px;font-size:28px}.dev-progress-subtitle{margin:0;opacity:.92}.dev-progress-meter{border-radius:12px;border:1px solid rgba(255,255,255,.3);background:#ffffff1f;padding:14px}.dev-progress-percent{font-size:32px;font-weight:700}.dev-progress-track{margin-top:10px;height:8px;background:#ffffff47;border-radius:999px;overflow:hidden}.dev-progress-fill{height:100%;background:linear-gradient(90deg,#22d3ee,#67e8f9)}.dev-progress-caption{margin-top:8px;font-size:12px}.dev-progress-banner{margin-top:12px;display:inline-flex;align-items:center;gap:8px;border:1px solid #bae6fd;background:#f0f9ff;color:#0c4a6e;border-radius:10px;padding:8px 10px}.dev-progress-stats{margin-top:14px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.dev-stat-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px;display:flex;gap:8px;align-items:center}.dev-stat-card span{display:block;font-size:12px;color:var(--muted)}.dev-stat-card strong{font-size:20px}.dev-view-toggle{margin-top:16px;display:inline-flex;border:1px solid var(--line);border-radius:10px;overflow:hidden}.dev-view-toggle button{border:none;background:#fff;color:var(--muted);padding:8px 14px;cursor:pointer}.dev-view-toggle button.active{background:#0f172a;color:#fff}.dev-batch-panel{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:linear-gradient(180deg,#f8fbff,#fff);padding:12px 14px;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.dev-batch-title{display:inline-flex;align-items:center;gap:8px;color:#0f172a;font-size:13px;font-weight:600}.dev-batch-title em{font-style:normal;font-size:12px;font-weight:500;color:#64748b;padding:3px 8px;border:1px solid #dbe3ef;border-radius:999px;background:#fff}.dev-batch-controls{display:inline-flex;align-items:center;gap:8px}.dev-batch-select{min-width:220px;height:36px;border:1px solid var(--line);border-radius:10px;padding:0 10px;background:#fff;font-size:13px;color:#0f172a}.dev-table-wrap{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:#fff;overflow:auto}.dev-table{width:100%;border-collapse:collapse;min-width:980px}.dev-table thead th{position:sticky;top:0;background:#f8fbff;z-index:1}.dev-table th,.dev-table td{border-bottom:1px solid #edf2f7;text-align:left;font-size:13px;padding:10px 12px}.group-row td{background:#f8fbff;border-bottom:1px solid #e7edf5;cursor:pointer;padding:8px 12px}.group-toggle{display:inline-flex;align-items:center;gap:6px;font-weight:600;color:#0f172a}.group-count{margin-left:10px;font-size:12px;color:#64748b}.dev-table select{min-width:120px;border:1px solid var(--line);border-radius:8px;padding:4px 7px;font-size:12px}.dev-table input[type=date]{border:1px solid var(--line);border-radius:8px;padding:4px 7px;font-size:12px}.dev-edit-btn{border:1px solid var(--line);background:#fff;border-radius:8px;padding:4px 8px;font-size:12px;display:inline-flex;align-items:center;gap:4px;cursor:pointer}.dev-edit-btn:disabled{opacity:.5;cursor:not-allowed}.task-title{max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.status-tag{display:inline-block;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.status-open{background:#eff6ff;color:#2563eb}.status-in_progress{background:#fff7ed;color:#c2410c}.status-pending_review{background:#f5f3ff;color:#6d28d9}.status-done{background:#ecfdf5;color:#059669}.status-blocked{background:#fef2f2;color:#dc2626}.status-dismissed{background:#f8fafc;color:#64748b}.row-progress{height:7px;width:120px;border-radius:999px;background:#e2e8f0;overflow:hidden}.row-progress div{height:100%;background:linear-gradient(90deg,#0ea5e9,#22d3ee)}.gantt-wrap{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.gantt-head{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:8px}.gantt-list{display:grid;gap:8px;max-height:560px;overflow:auto}.gantt-group{border:1px solid #edf2f7;border-radius:10px;background:#fff;padding:6px}.gantt-group-head{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:#0f172a;cursor:pointer;padding:2px 4px 6px}.gantt-group-head span{font-size:12px;color:#64748b}.gantt-row{border:1px solid #edf2f7;border-radius:10px;padding:8px}.gantt-meta{display:flex;justify-content:space-between;gap:8px;margin-bottom:6px}.gantt-meta strong{font-size:13px;max-width:70%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gantt-meta span{font-size:12px;color:var(--muted)}.gantt-track{height:12px;border-radius:999px;background:#f1f5f9;overflow:hidden}.gantt-bar{height:100%;border-radius:999px;display:flex;align-items:stretch}.gantt-bar i{display:block;height:100%;background:#ffffff6b}.dev-progress-loading,.dev-progress-error{margin-top:20px;display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:#fff;border-radius:10px;padding:12px 14px}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dev-progress-page .modal-overlay{position:fixed;inset:0;background:#0f172a73;display:flex;align-items:center;justify-content:center;z-index:1100}.dev-progress-page .modal-content{width:min(680px,92vw);background:#fff;border-radius:14px;overflow:hidden;border:1px solid #dbe3ef}.dev-progress-page .modal-header{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-bottom:1px solid #e2e8f0}.dev-progress-page .modal-header h2{margin:0;font-size:16px}.dev-progress-page .modal-close-btn{border:none;background:transparent;color:#334155;cursor:pointer}.dev-progress-page .modal-body{padding:14px}.dev-progress-page .form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.dev-progress-page .form-group label{font-size:12px;color:#475569}.dev-progress-page .form-group input,.dev-progress-page .form-group textarea,.dev-progress-page .form-group select{border:1px solid #dbe3ef;border-radius:8px;padding:8px 10px;font-size:13px}.dev-progress-page .form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.dev-progress-page .modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 14px;border-top:1px solid #e2e8f0;background:#f8fafc}.dev-progress-page .btn-primary,.dev-progress-page .btn-secondary{border-radius:8px;padding:7px 12px;border:1px solid #dbe3ef;cursor:pointer;font-size:13px}.dev-progress-page .btn-primary{background:#0f172a;color:#fff;border-color:#0f172a}.dev-progress-page .btn-secondary{background:#fff;color:#334155}@media(max-width:1100px){.dev-progress-hero{grid-template-columns:1fr}.dev-progress-stats{grid-template-columns:repeat(2,minmax(0,1fr))}.dev-progress-actions{flex-wrap:wrap;justify-content:flex-end}.dev-progress-page .form-row{grid-template-columns:1fr}.dev-batch-controls{width:100%;justify-content:flex-end}.dev-batch-select{min-width:180px}}.kb-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:kb-fade-in .15s ease}@keyframes kb-fade-in{0%{opacity:0}to{opacity:1}}.kb-modal{background:var(--card-bg, #fff);border-radius:12px;width:100%;max-width:520px;box-shadow:0 20px 60px #00000026;animation:kb-slide-up .2s ease;overflow:hidden}@keyframes kb-slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.kb-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:1px solid var(--border-color, #e2e8f0)}.kb-modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary, #1e293b);margin:0}.kb-modal-close{background:transparent;border:none;padding:4px;cursor:pointer;color:var(--text-secondary, #64748b);border-radius:6px;display:flex;align-items:center;transition:all .15s ease}.kb-modal-close:hover{background:var(--bg-hover, #f1f5f9);color:var(--text-primary, #1e293b)}.kb-modal-body{padding:24px}.kb-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px 20px;border-top:1px solid var(--border-color, #e2e8f0)}.kb-upload-dropzone{border:2px dashed var(--border-color, #e2e8f0);border-radius:12px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .15s ease;background:var(--bg-hover, #f8fafc);position:relative}.kb-upload-dropzone:hover,.kb-upload-dropzone-active{border-color:#1a73e8;background:#f0f6ff}.kb-upload-icon{color:#1a73e8;margin-bottom:12px}.kb-upload-text{font-size:15px;font-weight:500;color:var(--text-primary, #1e293b);margin:0 0 8px}.kb-upload-hint{display:block;font-size:13px;color:var(--text-secondary, #64748b);line-height:1.5}.kb-upload-file-input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.kb-upload-selected{margin-bottom:8px}.kb-upload-file-info{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-hover, #f8fafc);border:1px solid var(--border-color, #e2e8f0);border-radius:10px}.kb-upload-file-icon{color:#1a73e8;flex-shrink:0}.kb-upload-file-details{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.kb-upload-file-name{font-size:14px;font-weight:500;color:var(--text-primary, #1e293b);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kb-upload-file-size{font-size:12px;color:var(--text-secondary, #64748b)}.kb-upload-title-field{margin-top:20px}.kb-upload-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary, #64748b);margin-bottom:6px}.kb-upload-title-input{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-size:14px;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff);outline:none;transition:border-color .15s ease;box-sizing:border-box}.kb-upload-title-input:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.kb-upload-title-input:disabled{opacity:.6;cursor:not-allowed}.kb-upload-error{margin-top:12px;padding:10px 14px;background:#fef2f2;color:#dc2626;border-radius:8px;font-size:13px;border:1px solid #fecaca}.kb-doc-container{max-width:1200px;margin:0 auto;padding:32px 24px;font-family:Inter,system-ui,-apple-system,sans-serif}.kb-doc-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.kb-doc-header h1{font-size:28px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary, #1e293b);margin:0}.kb-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;background:var(--card-bg, #fff);color:var(--text-primary, #1e293b);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.kb-btn:hover{background:var(--bg-hover, #f1f5f9)}.kb-btn:disabled{opacity:.5;cursor:not-allowed}.kb-btn-primary{background:#1a73e8;color:#fff;border-color:#1a73e8}.kb-btn-primary:hover{background:#1557b0;border-color:#1557b0}.kb-btn-ghost{border-color:transparent;color:var(--text-secondary, #64748b);padding:6px 10px}.kb-btn-ghost:hover{color:var(--text-primary, #1e293b);background:var(--bg-hover, #f1f5f9)}.kb-btn-sm{padding:6px 12px;font-size:13px}.kb-doc-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px;flex-wrap:wrap}.kb-search-form{flex:1;min-width:200px}.kb-search-input-wrapper{position:relative;display:flex;align-items:center}.kb-search-icon{position:absolute;left:12px;color:var(--text-secondary, #64748b);pointer-events:none}.kb-search-input{width:100%;padding:9px 12px 9px 36px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-size:14px;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff);transition:border-color .15s ease;outline:none}.kb-search-input:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.kb-filter-group{display:flex;align-items:center;gap:8px}.kb-select-wrapper{position:relative;display:flex;align-items:center}.kb-select-icon{position:absolute;left:10px;color:var(--text-secondary, #64748b);pointer-events:none}.kb-select{padding:9px 32px 9px 30px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-size:14px;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff);cursor:pointer;outline:none;appearance:auto;transition:border-color .15s ease}.kb-select:focus{border-color:#1a73e8}.kb-table-container{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;overflow:hidden}.kb-table{width:100%;border-collapse:collapse;font-size:14px}.kb-table thead{background:var(--bg-hover, #f8fafc)}.kb-table th{padding:12px 16px;text-align:left;font-weight:600;font-size:13px;color:var(--text-secondary, #64748b);border-bottom:1px solid var(--border-color, #e2e8f0);white-space:nowrap}.kb-table td{padding:12px 16px;color:var(--text-primary, #1e293b);border-bottom:1px solid var(--border-color, #e2e8f0);vertical-align:middle}.kb-table tbody tr:last-child td{border-bottom:none}.kb-table-row-clickable{cursor:pointer;transition:background-color .1s ease}.kb-table-row-clickable:hover{background-color:var(--bg-hover, #f8fafc)}.kb-doc-title-cell{display:flex;align-items:center;gap:10px}.kb-doc-type-icon{color:var(--text-secondary, #64748b);flex-shrink:0}.kb-doc-title-text{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:280px}.kb-file-ext{font-size:12px;font-weight:600;color:var(--text-secondary, #64748b);background:var(--bg-hover, #f1f5f9);padding:2px 8px;border-radius:4px}.kb-tags-cell{display:flex;flex-wrap:wrap;gap:4px}.kb-tag-badge{display:inline-block;padding:2px 8px;background:#e8f0fe;color:#1a73e8;border-radius:4px;font-size:12px;font-weight:500;white-space:nowrap}.kb-status-badge{display:inline-block;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:600;white-space:nowrap}.kb-status-processing{background:#fef3cd;color:#856404}.kb-status-ready{background:#d4edda;color:#155724}.kb-status-failed{background:#f8d7da;color:#721c24}.kb-icon-btn{background:transparent;border:none;padding:6px;border-radius:6px;cursor:pointer;color:var(--text-secondary, #64748b);display:inline-flex;align-items:center;justify-content:center;transition:all .15s ease}.kb-icon-btn:hover{background:var(--bg-hover, #f1f5f9);color:var(--text-primary, #1e293b)}.kb-icon-btn-danger:hover{background:#fef2f2;color:#ea4335}.kb-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:8px 0}.kb-pagination-info{font-size:13px;color:var(--text-secondary, #64748b)}.kb-pagination-controls{display:flex;align-items:center;gap:8px}.kb-pagination-current{font-size:14px;font-weight:500;color:var(--text-primary, #1e293b);min-width:60px;text-align:center}.kb-loading{text-align:center;padding:60px 20px;color:var(--text-secondary, #64748b);font-size:15px}.kb-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;color:var(--text-secondary, #64748b);text-align:center;background:var(--card-bg, #fff);border:1px dashed var(--border-color, #e2e8f0);border-radius:8px}.kb-empty-state p{margin:16px 0 4px;font-size:16px;font-weight:500;color:var(--text-primary, #1e293b)}.kb-empty-state span{font-size:14px}.kb-error-banner{background:#fef2f2;color:#dc2626;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px;border:1px solid #fecaca}.kb-detail-container{max-width:1100px;margin:0 auto;padding:32px 24px;font-family:Inter,system-ui,-apple-system,sans-serif}.kb-detail-top-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.kb-detail-top-actions{display:flex;gap:8px;align-items:center}.kb-btn-warning{background:#f9ab00;color:#fff;border-color:#f9ab00}.kb-btn-warning:hover{background:#e09600;border-color:#e09600}.kb-spin{animation:kb-spin-anim 1s linear infinite}@keyframes kb-spin-anim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.kb-detail-grid{display:grid;grid-template-columns:1fr 300px;gap:24px;align-items:start}@media(max-width:860px){.kb-detail-grid{grid-template-columns:1fr}}.kb-detail-main,.kb-detail-sidebar{display:flex;flex-direction:column;gap:20px}.kb-detail-card{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:20px}.kb-detail-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary, #64748b);text-transform:uppercase;letter-spacing:.03em;margin-bottom:10px}.kb-detail-title-input{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-size:18px;font-weight:600;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff);outline:none;transition:border-color .15s ease;box-sizing:border-box}.kb-detail-title-input:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.kb-detail-textarea{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:8px;font-size:14px;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff);outline:none;resize:vertical;font-family:inherit;transition:border-color .15s ease;box-sizing:border-box}.kb-detail-textarea:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.kb-detail-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.kb-detail-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:#e8f0fe;color:#1a73e8;border-radius:4px;font-size:13px;font-weight:500}.kb-detail-tag-remove{background:transparent;border:none;cursor:pointer;padding:0;display:flex;align-items:center;color:#1a73e8;opacity:.6;transition:opacity .15s ease}.kb-detail-tag-remove:hover{opacity:1}.kb-detail-tag-add{display:flex;align-items:center;gap:4px}.kb-detail-tag-input{padding:4px 8px;border:1px solid var(--border-color, #e2e8f0);border-radius:4px;font-size:13px;outline:none;width:120px;color:var(--text-primary, #1e293b);background:var(--card-bg, #fff)}.kb-detail-tag-input:focus{border-color:#1a73e8}.kb-detail-summary{font-size:14px;line-height:1.7;color:var(--text-primary, #1e293b);background:var(--bg-hover, #f8fafc);padding:16px;border-radius:6px;white-space:pre-wrap}.kb-detail-text-preview{font-size:13px;line-height:1.6;color:var(--text-primary, #1e293b);background:var(--bg-hover, #f8fafc);padding:16px;border-radius:6px;max-height:500px;overflow-y:auto;white-space:pre-wrap;font-family:SFMono-Regular,Menlo,monospace;border:1px solid var(--border-color, #e2e8f0)}.kb-detail-meta-card{padding:20px}.kb-detail-meta-title{font-size:15px;font-weight:600;color:var(--text-primary, #1e293b);margin:0 0 16px;padding-bottom:12px;border-bottom:1px solid var(--border-color, #e2e8f0)}.kb-detail-meta-row{display:flex;align-items:center;gap:6px;padding:8px 0;font-size:13px;color:var(--text-secondary, #64748b)}.kb-detail-meta-row+.kb-detail-meta-row{border-top:1px solid var(--border-color, #f1f5f9)}.kb-detail-meta-label{font-weight:500;white-space:nowrap;min-width:60px}.kb-detail-meta-value{color:var(--text-primary, #1e293b);word-break:break-all;margin-left:auto;text-align:right}.kb-detail-status-processing{background:#fef3cd;color:#856404}.kb-detail-status-ready{background:#d4edda;color:#155724}.kb-detail-status-failed{background:#f8d7da;color:#721c24}.kb-chat-container{display:flex;height:calc(100vh - 64px);font-family:Inter,system-ui,-apple-system,sans-serif;overflow:hidden}.kb-chat-sidebar{width:250px;min-width:250px;background:var(--card-bg, #fff);border-right:1px solid var(--border-color, #e2e8f0);display:flex;flex-direction:column;overflow:hidden}.kb-chat-sidebar-header{padding:16px;border-bottom:1px solid var(--border-color, #e2e8f0)}.kb-btn-full{width:100%;justify-content:center}.kb-chat-conv-list{flex:1;overflow-y:auto;padding:8px}.kb-chat-sidebar-loading,.kb-chat-sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px;color:var(--text-secondary, #64748b);font-size:13px;gap:8px;text-align:center}.kb-chat-conv-item{display:flex;flex-direction:column;gap:4px;padding:10px 12px;border-radius:8px;cursor:pointer;transition:background-color .1s ease;margin-bottom:2px}.kb-chat-conv-item:hover{background:var(--bg-hover, #f8fafc)}.kb-chat-conv-active{background:#e8f0fe}.kb-chat-conv-active:hover{background:#d3e3fd}.kb-chat-conv-info{display:flex;align-items:center;gap:8px;min-width:0}.kb-chat-conv-icon{flex-shrink:0;color:var(--text-secondary, #64748b)}.kb-chat-conv-title{font-size:13px;font-weight:500;color:var(--text-primary, #1e293b);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.kb-chat-conv-meta{display:flex;justify-content:space-between;align-items:center;padding-left:22px}.kb-chat-conv-time{font-size:11px;color:var(--text-secondary, #94a3b8)}.kb-chat-conv-delete{background:transparent;border:none;padding:2px;cursor:pointer;color:var(--text-secondary, #94a3b8);border-radius:4px;display:flex;align-items:center;opacity:0;transition:all .15s ease}.kb-chat-conv-item:hover .kb-chat-conv-delete{opacity:1}.kb-chat-conv-delete:hover{color:#ea4335;background:#fef2f2}.kb-chat-main{flex:1;display:flex;flex-direction:column;background:var(--bg-color, #f8f9fa);overflow:hidden}.kb-chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:20px}.kb-chat-messages-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--text-secondary, #64748b);font-size:14px}.kb-chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;color:var(--text-secondary, #64748b);padding:40px}.kb-chat-empty-state h3{margin:16px 0 8px;font-size:20px;font-weight:600;color:var(--text-primary, #1e293b)}.kb-chat-empty-state p{font-size:14px;max-width:400px;line-height:1.6}.kb-chat-message{display:flex;gap:12px;max-width:760px;width:100%}.kb-chat-message-user{align-self:flex-end;flex-direction:row-reverse}.kb-chat-message-assistant{align-self:flex-start}.kb-chat-message-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.kb-chat-message-user .kb-chat-message-avatar{background:#1a73e8;color:#fff}.kb-chat-message-assistant .kb-chat-message-avatar{background:var(--border-color, #e2e8f0);color:var(--text-primary, #1e293b)}.kb-chat-message-content{display:flex;flex-direction:column;gap:4px;min-width:0;max-width:100%}.kb-chat-message-bubble{padding:12px 16px;border-radius:12px;font-size:14px;line-height:1.6;word-break:break-word}.kb-chat-message-user .kb-chat-message-bubble{background:#1a73e8;color:#fff;border-bottom-right-radius:4px}.kb-chat-message-user .kb-chat-message-bubble p{margin:0}.kb-chat-message-assistant .kb-chat-message-bubble{background:var(--card-bg, #fff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-bottom-left-radius:4px}.kb-chat-message-assistant .kb-chat-message-bubble p{margin:0 0 8px}.kb-chat-message-assistant .kb-chat-message-bubble p:last-child{margin-bottom:0}.kb-chat-message-assistant .kb-chat-message-bubble code{background:var(--bg-hover, #f1f5f9);padding:2px 6px;border-radius:4px;font-size:13px;font-family:SFMono-Regular,Menlo,monospace}.kb-chat-message-assistant .kb-chat-message-bubble pre{background:#1e293b;color:#e2e8f0;padding:12px 16px;border-radius:8px;overflow-x:auto;margin:8px 0}.kb-chat-message-assistant .kb-chat-message-bubble pre code{background:transparent;padding:0;color:inherit}.kb-chat-message-assistant .kb-chat-message-bubble ul,.kb-chat-message-assistant .kb-chat-message-bubble ol{margin:8px 0;padding-left:20px}.kb-chat-message-assistant .kb-chat-message-bubble li{margin-bottom:4px}.kb-chat-message-assistant .kb-chat-message-bubble h1,.kb-chat-message-assistant .kb-chat-message-bubble h2,.kb-chat-message-assistant .kb-chat-message-bubble h3{margin:12px 0 6px;font-weight:600}.kb-chat-message-assistant .kb-chat-message-bubble blockquote{border-left:3px solid var(--border-color, #e2e8f0);margin:8px 0;padding:4px 12px;color:var(--text-secondary, #64748b)}.kb-chat-references{display:flex;flex-wrap:wrap;align-items:center;gap:6px;margin-top:6px;padding:8px 12px;background:var(--bg-hover, #f8fafc);border-radius:8px;font-size:12px}.kb-chat-references-label{display:flex;align-items:center;gap:4px;color:var(--text-secondary, #64748b);font-weight:500;white-space:nowrap}.kb-chat-reference-link{background:#e8f0fe;color:#1a73e8;border:none;padding:3px 8px;border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .15s ease;font-weight:500}.kb-chat-reference-link:hover{background:#d3e3fd}.kb-chat-message-time{font-size:11px;color:var(--text-secondary, #94a3b8);padding:0 4px}.kb-chat-message-user .kb-chat-message-time{text-align:right}.kb-chat-typing{display:flex;align-items:center;gap:4px;padding:16px 20px}.kb-typing-dot{width:8px;height:8px;border-radius:50%;background:var(--text-secondary, #94a3b8);animation:kb-typing-bounce 1.4s infinite ease-in-out both}.kb-typing-dot:nth-child(1){animation-delay:-.32s}.kb-typing-dot:nth-child(2){animation-delay:-.16s}@keyframes kb-typing-bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.kb-chat-input-area{padding:16px 24px 20px;background:var(--bg-color, #f8f9fa);border-top:1px solid var(--border-color, #e2e8f0)}.kb-chat-input-wrapper{display:flex;align-items:flex-end;gap:8px;background:var(--card-bg, #fff);border:1px solid var(--border-color, #e2e8f0);border-radius:12px;padding:8px 12px;transition:border-color .15s ease;max-width:760px;margin:0 auto}.kb-chat-input-wrapper:focus-within{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81a}.kb-chat-input{flex:1;border:none;outline:none;resize:none;font-size:14px;line-height:1.5;color:var(--text-primary, #1e293b);background:transparent;font-family:inherit;max-height:160px;padding:4px 0}.kb-chat-input::placeholder{color:var(--text-secondary, #94a3b8)}.kb-chat-send-btn{background:#1a73e8;color:#fff;border:none;padding:8px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .15s ease;flex-shrink:0}.kb-chat-send-btn:hover:not(:disabled){background:#1557b0}.kb-chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:overlayFadeIn .2s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.upload-modal{background:#fff;border-radius:12px;width:100%;max-width:520px;box-shadow:0 20px 60px #00000026;animation:modalSlideIn .3s ease-out;overflow:hidden}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.upload-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid #e2e8f0}.upload-modal-header h2{margin:0;font-size:1.2rem;font-weight:700;color:#1a1a2e}.modal-close-btn{background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:6px;transition:all .15s;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:#4a5568;background:#f7fafc}.modal-close-btn:disabled{cursor:not-allowed;opacity:.5}.upload-modal-body{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-group:last-child{margin-bottom:0}.form-label{display:block;font-size:.875rem;font-weight:600;color:#4a5568;margin-bottom:.5rem}.required{color:#ea4335}.form-input{width:100%;padding:.6rem .85rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.9rem;outline:none;transition:all .2s;box-sizing:border-box;background-color:#fff;color:#1a1a2e}.form-input:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81f}.form-input:disabled{background:#f7fafc;cursor:not-allowed}.drop-zone{border:2px dashed #e2e8f0;border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:#fafbfc}.drop-zone:hover{border-color:#cbd5e0;background:#f7fafc}.drop-zone-active{border-color:#1a73e8;background:#eff6ff}.drop-zone-has-file{border-style:solid;border-color:#d1fae5;background:#f0fdf4;padding:1rem}.drop-zone-content{pointer-events:none}.drop-icon{color:#a0aec0;margin-bottom:.75rem}.drop-text{font-size:.95rem;color:#4a5568;margin:0 0 .4rem;font-weight:500}.drop-hint{font-size:.8rem;color:#a0aec0;margin:0}.file-selected{display:flex;align-items:center;gap:.75rem;text-align:left}.file-icon{color:#1a73e8;flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{display:block;font-size:.9rem;font-weight:600;color:#2d3748;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-size{display:block;font-size:.8rem;color:#718096;margin-top:2px}.file-remove-btn{background:none;border:none;color:#a0aec0;cursor:pointer;padding:4px;border-radius:4px;transition:all .15s;flex-shrink:0;display:flex;align-items:center}.file-remove-btn:hover{color:#e53e3e;background:#fee2e2}.upload-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fff5f5;border:1px solid #fed7d7;border-radius:8px;color:#c53030;font-size:.875rem;margin-top:1rem}.upload-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid #e2e8f0;background:#f8f9fa}.upload-modal-footer .btn{display:inline-flex;align-items:center;gap:6px;padding:.5rem 1.25rem;border-radius:8px;font-weight:600;font-size:.9rem}.meeting-list-container{padding:2rem;max-width:1400px;margin:0 auto;animation:meetingFadeIn .4s ease-out}@keyframes meetingFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.meeting-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.meeting-header h1{font-size:2rem;font-weight:700;color:#1a1a2e;margin:0;letter-spacing:-.5px}.meeting-subtitle{color:#718096;margin-top:.5rem;font-size:.95rem;margin-bottom:0}.meeting-header-actions{display:flex;align-items:center;gap:.75rem}.search-box{display:flex;align-items:center;border:1px solid #e2e8f0;border-radius:8px;padding:0 .75rem;background:#fff;transition:all .2s}.search-box:focus-within{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81f}.search-icon{color:#a0aec0;flex-shrink:0}.search-input{border:none;outline:none;padding:.5rem;font-size:.875rem;color:#4a5568;background:transparent;width:180px}.search-input::placeholder{color:#cbd5e0}.meeting-attendees-sub{font-size:.75rem;color:#a0aec0;margin-top:2px}.col-id{font-family:JetBrains Mono,Courier New,monospace;font-size:.75rem;color:#a0aec0;white-space:nowrap;cursor:text;-webkit-user-select:text;user-select:text}.col-date{white-space:nowrap;font-size:.875rem;color:#718096}.type-filter-select{padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:8px;font-size:.875rem;color:#4a5568;background:#fff;cursor:pointer;outline:none;transition:all .2s}.type-filter-select:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e81f}.upload-btn{display:flex;align-items:center;gap:8px;padding:.6rem 1.25rem;border-radius:8px;font-weight:600}.meeting-table-wrapper{background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000000d;overflow:hidden}.meeting-table{width:100%;border-collapse:collapse}.meeting-table thead{background:#f8f9fa}.meeting-table th{padding:.85rem 1rem;text-align:left;font-size:.85rem;font-weight:600;color:#4a5568;border-bottom:2px solid #e2e8f0;white-space:nowrap}.meeting-table td{padding:.85rem 1rem;border-bottom:1px solid #f0f0f0;font-size:.9rem;color:#2d3748}.meeting-row{cursor:pointer;transition:background .15s ease}.meeting-row:hover{background:#f7fafc}.meeting-row:last-child td{border-bottom:none}.meeting-title-cell{display:flex;align-items:center;gap:.5rem;font-weight:500}.title-icon{color:#a0aec0;flex-shrink:0}.col-type{white-space:nowrap}.meeting-type-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.8rem;font-weight:500;background:#edf2f7;color:#4a5568}.col-duration,.col-creator,.col-time{white-space:nowrap;color:#718096}.col-actions{width:60px;text-align:center}.meeting-status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.3px;white-space:nowrap}.btn-delete-icon{background:#fff;border:1px solid #fed7d7;color:#e53e3e;width:32px;height:32px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.btn-delete-icon:hover{background:#fed7d7;color:#c53030}.meeting-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding:.5rem 0}.pagination-info{font-size:.875rem;color:#718096}.pagination-buttons{display:flex;gap:.75rem}.btn-sm{display:inline-flex;align-items:center;gap:4px;padding:.4rem .8rem;font-size:.85rem;border-radius:6px}.empty-state{text-align:center;padding:4rem 2rem;background:#f8fafc;border-radius:16px;border:2px dashed #e2e8f0;color:#a0aec0}.empty-state h3{margin:1rem 0 .5rem;color:#4a5568;font-size:1.25rem}.empty-state p{margin:0;font-size:.95rem}.loading-center{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:4rem;color:#718096;font-size:1rem}.error-message{text-align:center;padding:3rem;color:#ea4335;font-size:1rem}.meeting-detail-container{padding:2rem;max-width:1200px;margin:0 auto;animation:meetingDetailFadeIn .4s ease-out}@keyframes meetingDetailFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.meeting-toolbar{margin-bottom:1.5rem}.meeting-toolbar .btn{display:inline-flex;align-items:center;gap:.5rem}.meeting-detail-header{margin-bottom:2rem}.meeting-detail-title-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.meeting-detail-title-row h1{font-size:1.75rem;font-weight:700;color:#1a1a2e;margin:0}.meeting-detail-meta{display:flex;gap:1.5rem;margin-top:.5rem;font-size:.875rem;color:#718096;flex-wrap:wrap}.meeting-type-tag{display:inline-block;padding:2px 10px;border-radius:4px;font-size:.8rem;font-weight:600;background:#edf2f7;color:#4a5568}.meeting-status-badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:700;letter-spacing:.3px;white-space:nowrap}.status-uploading,.status-transcribing,.status-summarizing{background:#fef3c7;color:#92400e}.status-transcribed{background:#dbeafe;color:#1e40af}.status-summarized{background:#d1fae5;color:#065f46}.status-archived{background:#ede9fe;color:#5b21b6}.status-failed{background:#fee2e2;color:#991b1b}.status-unknown{background:#f3f4f6;color:#6b7280}.processing-banner{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:#fffbeb;border:1px solid #fde68a;border-radius:8px;color:#92400e;font-weight:500;margin-bottom:1.5rem}.detail-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 4px #0000000a}.section-title{font-size:1.1rem;font-weight:600;color:#2d3748;margin:0}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.section-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-sm{display:inline-flex;align-items:center;gap:6px;padding:.4rem .8rem;font-size:.85rem;border-radius:6px}.audio-section .section-title{margin-bottom:1rem}.audio-player-wrapper{background:#f8f9fa;border-radius:8px;padding:1rem}.audio-player{width:100%;border-radius:4px}.audio-loading,.audio-unavailable{text-align:center;padding:1rem;color:#718096;display:flex;align-items:center;justify-content:center;gap:.5rem}.speaker-mapping-panel{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;padding:1rem 1.25rem;margin-bottom:1rem}.speaker-mapping-header{display:flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:#4a5568;margin-bottom:.75rem}.speaker-hint{font-size:.75rem;font-weight:400;color:#a0aec0;margin-left:auto}.speaker-mapping-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.6rem}.speaker-mapping-item{display:flex;align-items:center;gap:.5rem}.speaker-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.speaker-id-label{font-size:.75rem;font-weight:600;min-width:80px;padding:4px 8px;border-radius:4px;text-align:center;white-space:nowrap}.speaker-name-input{flex:1;padding:6px 10px;border:1.5px solid #e2e8f0;border-radius:6px;font-size:.875rem;outline:none;transition:all .2s;background:#fff}.speaker-name-input:focus{border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e826}.speaker-name-input::placeholder{color:#cbd5e0;font-size:.8rem}.segments-list{max-height:600px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px}.segment-item{padding:.6rem 1rem;border-bottom:1px solid #f0f0f0;border-left:3px solid transparent;transition:background .15s}.segment-item:hover{background:#f8fafc}.segment-item:last-child{border-bottom:none}.segment-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.3rem}.segment-speaker{font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:4px;white-space:nowrap}.segment-time{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;color:#718096;background:none;border:none;cursor:pointer;padding:2px 6px;border-radius:4px;transition:all .15s;font-family:JetBrains Mono,Courier New,monospace}.segment-time:hover{background:#edf2f7;color:#1a73e8}.segment-time-playing{background:#fee2e2;color:#dc2626}.segment-time-playing:hover{background:#fecaca;color:#b91c1c}.segment-text{width:100%;border:1px solid transparent;background:transparent;padding:4px 6px;font-size:.9rem;line-height:1.6;color:#2d3748;resize:none;border-radius:4px;outline:none;transition:all .15s;font-family:inherit}.segment-text:hover{border-color:#e2e8f0;background:#fff}.segment-text:focus{border-color:#1a73e8;background:#fff;box-shadow:0 0 0 2px #1a73e81a}.no-segments{text-align:center;padding:2rem;color:#a0aec0}.summary-section{border-left:4px solid #1a73e8}.summary-content{background:#f8f9fa;border-radius:8px;padding:1.5rem;line-height:1.8;color:#2d3748}.summary-content h1,.summary-content h2,.summary-content h3{color:#1a1a2e;margin-top:1.25rem;margin-bottom:.5rem}.summary-content h1:first-child,.summary-content h2:first-child,.summary-content h3:first-child{margin-top:0}.summary-content ul,.summary-content ol{padding-left:1.5rem}.summary-content li{margin-bottom:.4rem}.summary-content p{margin:.5rem 0}.summary-content code{background:#edf2f7;padding:2px 6px;border-radius:3px;font-size:.85em}.summary-content blockquote{border-left:3px solid #e2e8f0;margin:1rem 0;padding:.5rem 1rem;color:#718096;background:#fff;border-radius:0 4px 4px 0}.summary-content table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.875rem;overflow-x:auto;display:block}.summary-content thead{background:#edf2f7}.summary-content th{padding:.6rem .75rem;text-align:left;font-weight:600;color:#2d3748;border:1px solid #e2e8f0;white-space:nowrap}.summary-content td{padding:.5rem .75rem;border:1px solid #e2e8f0;color:#4a5568}.summary-content tbody tr:nth-child(2n){background:#f7fafc}.summary-content tbody tr:hover{background:#edf2f7}.summary-content ul.contains-task-list,.summary-content .task-list-item{list-style:none}.summary-content ul.contains-task-list{padding-left:.5rem}.summary-content .task-list-item input[type=checkbox]{margin-right:.5rem;width:15px;height:15px;accent-color:#1a73e8;vertical-align:middle}.summary-content hr{border:none;border-top:2px solid #e2e8f0;margin:1.5rem 0}.summary-content strong{font-weight:700;color:#1a1a2e}.summary-content del{color:#a0aec0}.summary-content pre{background:#1a1a2e;color:#e2e8f0;padding:1rem;border-radius:6px;overflow-x:auto;margin:1rem 0;font-size:.85rem;line-height:1.6}.summary-content pre code{background:none;padding:0;color:inherit;font-size:inherit}.summary-content ul ul,.summary-content ol ol,.summary-content ul ol,.summary-content ol ul{margin-top:.25rem;margin-bottom:.25rem}.summary-content h4{color:#2d3748;font-size:.95rem;font-weight:600;margin-top:1rem;margin-bottom:.4rem}.summary-content h5{color:#4a5568;font-size:.875rem;font-weight:600;margin-top:.75rem;margin-bottom:.3rem}.summary-empty{text-align:center;padding:2.5rem;color:#a0aec0}.summary-empty p{margin-top:.75rem;font-size:.95rem}.summary-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:#718096}.btn-archive{background:#7c3aed;color:#fff;border:none;cursor:pointer;transition:background .2s}.btn-archive:hover{background:#6d28d9}.btn-archive:disabled{opacity:.6;cursor:not-allowed}.archive-badge{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ede9fe;border-radius:8px;color:#5b21b6;font-weight:600;font-size:.9rem;margin-bottom:1rem}.archive-link{display:inline-flex;align-items:center;gap:4px;margin-left:auto;color:#7c3aed;text-decoration:none;font-weight:500;font-size:.85rem}.archive-link:hover{text-decoration:underline}.failed-section{display:flex;align-items:flex-start;gap:1rem;background:#fff5f5;border-color:#fed7d7;color:#c53030}.failed-section h3{margin:0 0 .25rem;font-size:1rem}.failed-section p{margin:0;font-size:.9rem;color:#9b2c2c}.meeting-detail-attendees{display:flex;align-items:center;gap:.4rem;margin-top:.4rem;font-size:.85rem;color:#718096}.segment-speaker-wrapper{position:relative}.segment-speaker-clickable{cursor:pointer;transition:opacity .15s}.segment-speaker-clickable:hover{opacity:.8}.speaker-dropdown{position:absolute;top:100%;left:0;z-index:20;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 4px 12px #0000001f;min-width:140px;padding:4px 0;margin-top:4px}.speaker-dropdown-item{display:flex;align-items:center;gap:.5rem;padding:6px 12px;cursor:pointer;font-size:.8rem;transition:background .1s}.speaker-dropdown-item:hover{background:#f0f4ff}.summary-options{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;padding:1rem;margin-bottom:1rem;display:flex;flex-direction:column;gap:.75rem}.summary-option-row{display:flex;align-items:flex-start;gap:.75rem}.summary-option-label{font-size:.8rem;font-weight:600;color:#4a5568;min-width:90px;padding-top:6px;white-space:nowrap}.summary-option-select{flex:1;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#4a5568;background:#fff;outline:none;cursor:pointer}.summary-option-select:focus{border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e81f}.summary-prompt-textarea{flex:1;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#4a5568;resize:vertical;outline:none;font-family:inherit;line-height:1.5}.summary-prompt-textarea:focus{border-color:#1a73e8;box-shadow:0 0 0 2px #1a73e81f}.summary-prompt-textarea::placeholder{color:#cbd5e0}.prev-meeting-picker{flex:1;position:relative}.prev-meeting-display{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border:1px solid #e2e8f0;border-radius:6px;background:#fff;cursor:pointer;min-height:34px;transition:border-color .2s}.prev-meeting-display:hover{border-color:#cbd5e0}.prev-meeting-placeholder{color:#cbd5e0;font-size:.85rem}.prev-meeting-selected{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prev-meeting-short-id{font-family:JetBrains Mono,Courier New,monospace;font-size:.7rem;color:#a0aec0;background:#f0f4ff;padding:1px 5px;border-radius:3px;flex-shrink:0}.prev-meeting-date{font-size:.75rem;color:#718096;flex-shrink:0}.prev-meeting-clear{background:none;border:none;cursor:pointer;color:#a0aec0;padding:2px;border-radius:3px;display:flex;align-items:center;flex-shrink:0}.prev-meeting-clear:hover{color:#e53e3e;background:#fff5f5}.prev-meeting-dropdown{position:absolute;top:100%;left:0;right:0;z-index:30;background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px #0000001f;margin-top:4px;overflow:hidden}.prev-meeting-search-input{width:100%;padding:8px 12px;border:none;border-bottom:1px solid #e2e8f0;font-size:.85rem;outline:none;color:#2d3748;box-sizing:border-box}.prev-meeting-search-input::placeholder{color:#cbd5e0}.prev-meeting-list{max-height:240px;overflow-y:auto}.prev-meeting-item{padding:8px 12px;cursor:pointer;transition:background .1s;border-bottom:1px solid #f7fafc}.prev-meeting-item:last-child{border-bottom:none}.prev-meeting-item:hover{background:#f0f4ff}.prev-meeting-item-active{background:#ebf4ff}.prev-meeting-item-main{display:flex;align-items:center;gap:.5rem;font-size:.85rem}.prev-meeting-item-title{color:#2d3748;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prev-meeting-item-attendees{font-size:.72rem;color:#a0aec0;margin-top:2px;padding-left:3.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prev-meeting-empty{padding:1rem;text-align:center;color:#a0aec0;font-size:.85rem}.spin{animation:spinAnim 1s linear infinite}@keyframes spinAnim{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:4rem;color:#718096}.error-message{text-align:center;padding:3rem;color:#ea4335}@media(max-width:768px){.meeting-detail-container{padding:1rem}.meeting-detail-title-row h1{font-size:1.3rem}.section-header{flex-direction:column;align-items:flex-start}.speaker-mapping-grid{grid-template-columns:1fr}.segments-list{max-height:400px}}
