.profile-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;display:flex;align-items:flex-start;gap:24px}.profile-photo{width:96px;height:96px;border-radius:50%;object-fit:cover;border:3px solid var(--primary-soft)}.profile-avatar{width:96px;height:96px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);color:#fff;font-size:40px;font-weight:800}.profile-photo-actions{display:flex;gap:8px}.profile-info{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:12px}.profile-name-row{display:flex;align-items:center;gap:12px}.profile-info h3{font-size:22px;font-weight:800;color:var(--text);margin:0}.profile-edit label{font-size:13px;font-weight:600;color:var(--text-secondary)}.profile-edit-actions{display:flex;gap:10px}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;max-width:640px;display:flex;flex-direction:column;gap:4px}.settings-card h3{font-size:16px;font-weight:700;color:var(--text);margin:0 0 12px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--border)}.settings-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.settings-saved{font-size:13px;font-weight:600;color:var(--success)}.toggle{position:relative;display:inline-block;width:44px;height:24px;flex:0 0 44px}.toggle-slider{position:absolute;cursor:pointer;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:24px;transition:background-color var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform var(--transition-fast)}@media (max-width: 640px){.profile-card{flex-direction:column;align-items:center;text-align:center}.profile-name-row,.profile-meta{justify-content:center}.setting-row{flex-direction:column;align-items:flex-start;gap:10px}}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118278c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:100;animation:confirm-fade-in .2s ease}.confirm-dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:420px;width:100%;padding:28px 32px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;animation:confirm-scale-in .2s cubic-bezier(.16,1,.3,1)}.confirm-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--danger-soft);color:var(--danger);font-size:28px;line-height:1}.confirm-title{font-size:20px;font-weight:800;color:var(--text);letter-spacing:-.02em}.confirm-message{font-size:15px;color:var(--text-secondary);line-height:1.6;margin:0}.confirm-actions{display:flex;gap:12px;width:100%;margin-top:8px}.confirm-actions .btn{flex:1 1 auto}@keyframes confirm-fade-in{0%{opacity:0}to{opacity:1}}@keyframes confirm-scale-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media (prefers-reduced-motion: reduce){.confirm-overlay,.confirm-dialog{animation:none}}.login-links{display:flex;justify-content:center;gap:8px;margin-top:12px;font-size:14px}.login-links a{color:var(--primary);font-weight:600;text-decoration:none;padding:10px 12px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast),color var(--transition-fast)}.login-links a:hover{background:var(--primary-soft);color:var(--primary-hover)}.login-links a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1118278c;display:flex;align-items:center;justify-content:center;padding:20px;z-index:90}.modal-dialog{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:520px;width:100%;padding:24px;display:flex;flex-direction:column;gap:14px}.modal-dialog h3{font-size:18px;font-weight:700;margin:0}.users-table-wrapper{overflow-x:auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.users-table{width:100%;border-collapse:collapse;font-size:14px}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border)}.users-table th{background:var(--surface-alt);font-weight:700;color:var(--text-secondary);text-transform:uppercase;font-size:12px;letter-spacing:.04em}.users-table tr:last-child td{border-bottom:none}.users-table select{padding:6px 8px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text)}.badge-muted{background:var(--surface-alt);color:var(--text-muted)}*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f7f9f8;--surface: #ffffff;--surface-alt: #eef4f2;--surface-elevated: #ffffff;--border: #d8e3e0;--border-strong: #b8c9c4;--text: #1f2937;--text-secondary: #4b5563;--text-muted: #6b7280;--primary: #0f766e;--primary-hover: #115e59;--primary-soft: #ccfbf1;--danger: #dc2626;--danger-hover: #b91c1c;--danger-soft: #fee2e2;--success: #047857;--warning: #d97706;--radius: 12px;--radius-sm: 8px;--radius-pill: 999px;--shadow: 0 1px 3px rgba(31, 41, 55, .06), 0 1px 2px rgba(31, 41, 55, .04);--shadow-md: 0 4px 12px rgba(31, 41, 55, .06);--shadow-lg: 0 10px 30px rgba(31, 41, 55, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--modal-overlay-bg: rgba(16, 24, 40, .75);--absa: #7c3aed;--asqp: #0f766e;--ssa: #047857;--neg: #dc2626;--neu: #9ca3af;--pos: #047857}html,body,#root{height:100%}body{font-family:Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}::selection{background:var(--primary-soft);color:var(--primary-hover)}.app-shell{display:flex;flex-direction:column;height:100vh;height:100dvh;scrollbar-gutter:stable both-edges}.app-header{display:flex;align-items:center;flex-shrink:0;padding:0 24px;height:64px;min-height:64px;background:#ffffffeb;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.app-title{font-size:20px;font-weight:800;color:var(--primary);text-decoration:none;letter-spacing:-.03em;display:inline-flex;align-items:center;gap:10px}.app-title:before{content:"";display:inline-block;width:24px;height:24px;background:var(--primary);border-radius:7px;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' d='M5 12l5 5 9-10'/%3E%3C/svg%3E") center / 16px no-repeat;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='none' stroke='%23fff' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round' d='M5 12l5 5 9-10'/%3E%3C/svg%3E") center / 16px no-repeat}.app-body{display:flex;flex:1 1 auto;min-height:0}.app-sidebar{width:240px;flex:0 0 auto;display:flex;flex-direction:column;justify-content:space-between;gap:16px;padding:16px 12px;background:var(--surface);border-right:1px solid var(--border);overflow:hidden}.sidebar-nav{display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-link:hover{background:var(--surface-alt);color:var(--text)}.sidebar-link:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.sidebar-link.active{background:var(--primary-soft);color:var(--primary)}.sidebar-link--disabled{color:var(--text-muted);cursor:not-allowed;opacity:.7}.sidebar-link--disabled:hover{background:transparent;color:var(--text-muted)}.sidebar-footer{display:flex;flex-direction:column;gap:10px;padding-top:12px;border-top:1px solid var(--border)}.sidebar-user{color:var(--text-muted);font-weight:600;font-size:14px;padding:0 12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-logout{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 14px;border:1px solid transparent;border-radius:var(--radius-sm);background:var(--danger-soft);color:var(--danger);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background-color var(--transition-fast),color var(--transition-fast)}.sidebar-logout:hover{background:var(--danger);color:#fff}.sidebar-logout:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.app-main{flex:1 1 auto;min-width:0;min-height:0;padding:28px 24px;overflow-y:auto}.app-header .notification-bell{margin-left:auto}@media (prefers-reduced-motion: reduce){.app-sidebar,.sidebar-link,.sidebar-logout{transition:none}}.sidebar-section{display:flex;flex-direction:column;gap:6px}.sidebar-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:0 12px;margin-top:8px}.sidebar-section-links{display:flex;flex-direction:column;gap:4px}.sidebar-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex:0 0 18px}.sidebar-icon svg{width:100%;height:100%}.home-dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}.stat-card-value{font-size:28px;font-weight:800;color:var(--text);line-height:1}.stat-card-label{font-size:13px;font-weight:600;color:var(--text-secondary)}.stat-card.absa .stat-card-value{color:var(--absa)}.stat-card.asqp .stat-card-value{color:var(--asqp)}.stat-card.ssa .stat-card-value{color:var(--ssa)}.welcome-banner{background:linear-gradient(135deg,var(--primary-soft) 0%,rgba(15,118,110,.08) 100%);border:1px solid var(--primary-soft);border-radius:var(--radius);padding:22px 24px;margin-bottom:24px}.welcome-banner h1{font-size:20px;font-weight:800;color:var(--text);margin:0 0 6px}.welcome-banner p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}@media (max-width: 640px){.home-dashboard{grid-template-columns:repeat(2,1fr)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid transparent;border-radius:var(--radius-sm);padding:9px 16px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.btn:active:not(:disabled){transform:translateY(1px)}.btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--text)}.btn-ghost:hover:not(:disabled){background:var(--surface-alt);border-color:var(--border-strong)}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:transparent}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff;box-shadow:0 4px 10px #d6454540}.btn-small{padding:5px 11px;font-size:13px}input[type=text],input[type=password],input[type=number],textarea,select{width:100%;padding:10px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}input::placeholder,textarea::placeholder{color:var(--text-muted);opacity:.8}input:hover,textarea:hover,select:hover{border-color:#b0b9c8}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft);background:var(--surface)}input:disabled,textarea:disabled,select:disabled{background:var(--surface-alt);color:var(--text-muted);cursor:not-allowed}textarea{resize:vertical;min-height:120px;line-height:1.5}label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--text-muted)}.form-error{background:var(--danger-soft);color:var(--danger);border:1px solid #f2c9c9;border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;margin:12px 0}.form-success{background:#e8f6ee;color:var(--success);border:1px solid #bce3cb;border-radius:var(--radius-sm);padding:10px 14px;font-size:14px;margin:12px 0}.login-page{display:flex;align-items:center;justify-content:center;gap:48px;min-height:100vh;padding:28px 40px;background:radial-gradient(circle at 20% 20%,rgba(15,118,110,.06) 0%,transparent 40%),radial-gradient(circle at 85% 80%,rgba(124,58,237,.05) 0%,transparent 40%),var(--bg)}.login-hero{flex:1 1 420px;max-width:600px;display:flex;flex-direction:column;align-items:flex-start;gap:22px;padding:48px 44px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.login-hero:before{content:"✓";display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--primary);color:#fff;border-radius:var(--radius);font-size:32px;font-weight:800}.login-hero-title{font-size:56px;font-weight:700;letter-spacing:-.03em;color:var(--primary);line-height:1.05;text-wrap:balance}.login-hero-subtitle{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.01em;line-height:1.35}.login-hero-desc{font-size:16px;color:var(--text-secondary);line-height:1.7;max-width:500px}.login-hero-features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;width:100%;margin-top:8px}.login-hero-feature{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:18px 14px;background:var(--surface-alt);border:1px solid var(--border);border-radius:var(--radius);transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.login-hero-feature:hover{transform:translateY(-3px);background:var(--primary-soft);box-shadow:var(--shadow-md)}.login-hero-feature .feature-icon{font-size:32px;line-height:1}.login-hero-feature .feature-text{font-size:13px;font-weight:600;color:var(--text-secondary);line-height:1.35}@media (max-width: 900px){.login-page{flex-direction:column;padding:24px}.login-hero,.login-card{max-width:100%;width:100%}}@media (max-width: 640px){.login-hero-features{grid-template-columns:1fr}.login-hero{padding:32px 24px}.login-hero-title{font-size:44px}.login-hero-subtitle{font-size:18px}}.login-badges{display:inline-flex;gap:10px;flex-wrap:wrap;margin-top:4px}.login-badges .badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 18px;border-radius:var(--radius-pill);font-size:12px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.login-badges .badge:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0000001f}.login-card{flex:0 1 400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:40px 36px;width:100%;max-width:400px;display:flex;flex-direction:column;gap:18px}.login-card h1{font-size:28px;font-weight:800;color:var(--primary);text-align:center;letter-spacing:-.03em;display:flex;align-items:center;justify-content:center;gap:12px;text-wrap:balance}.login-card h1:before{content:"✓";display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--primary);color:#fff;border-radius:var(--radius-sm);font-size:18px;font-weight:800}.login-subtitle{text-align:center;color:var(--text-muted);font-size:14px;margin-bottom:4px;line-height:1.5}.login-card label{display:flex;flex-direction:column;gap:6px;font-size:14px;font-weight:600;color:var(--text)}.login-card input,.login-card .form-group input{width:100%;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:15px;line-height:1.4;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-card input:focus,.login-card .form-group input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}.login-card input::placeholder,.login-card .form-group input::placeholder{color:var(--text-muted);opacity:1}.login-card .btn-primary{width:100%;margin-top:8px;padding:13px 16px;font-size:15px}.invite-page{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:32px 24px;min-height:100%;background:transparent}.invite-card{flex:0 1 560px;max-width:100%}.invite-header{display:flex;flex-direction:column;align-items:center;gap:10px;padding-bottom:18px;border-bottom:1px solid var(--border);margin-bottom:4px}.invite-header h1{margin:0}.invite-project-name{font-size:16px;font-weight:600;color:var(--text);text-align:center;margin:0;word-break:break-word}.invite-section{padding:16px 0;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.invite-section:last-child{border-bottom:none;padding-bottom:0}.invite-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0}.invite-inviter{display:flex;align-items:center;gap:12px}.invite-inviter-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0}.invite-inviter-info{display:flex;flex-direction:column;gap:2px;min-width:0}.invite-inviter-name{font-size:14px;font-weight:600;color:var(--text)}.invite-inviter-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-muted{color:var(--text-muted);font-size:13px;margin:0}.invite-task-summary{font-size:14px;line-height:1.55;color:var(--text);margin:0}.invite-task-details{margin-top:4px}.invite-task-details summary{cursor:pointer;font-size:13px;font-weight:600;color:var(--primary);padding:6px 0;list-style:none;-webkit-user-select:none;user-select:none}.invite-task-details summary::-webkit-details-marker{display:none}.invite-task-details summary:before{content:"▶";display:inline-block;transition:transform var(--transition-fast, .15s ease);font-size:9px;margin-right:6px}.invite-task-details[open] summary:before{transform:rotate(90deg)}.invite-task-guide{margin-top:10px;padding:14px 16px;background:var(--bg-elevated, var(--surface));border:1px solid var(--border);border-radius:var(--radius-sm, 6px);display:flex;flex-direction:column;gap:14px}.invite-task-section h3{font-size:13px;font-weight:700;color:var(--text);margin:0 0 4px}.invite-task-section p{font-size:13px;line-height:1.5;color:var(--text);margin:0 0 6px}.invite-task-section ul{margin:0 0 6px;padding-left:18px;font-size:13px;color:var(--text)}.invite-task-section li{margin-bottom:2px}.invite-task-example{background:var(--code-bg, rgba(15, 23, 42, .04));border-left:3px solid var(--primary);padding:8px 12px;border-radius:0 4px 4px 0;font-size:12px!important;color:var(--text-muted)!important}.invite-actions-row{display:flex;gap:10px;flex-wrap:wrap}.invite-actions-row .btn{flex:1;min-width:140px}.invite-login-prompt{display:flex;flex-direction:column;gap:12px;align-items:stretch}.invite-login-prompt p{margin:0;text-align:center;color:var(--text-muted);font-size:14px}.invite-status{padding:10px 14px;border-radius:var(--radius-sm, 6px);font-size:14px;font-weight:500;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.invite-status-accepted{background:#0596691a;color:#047857}.invite-status-rejected{background:#d645451a;color:#b91c1c}.invite-status .btn{margin-left:auto}.progress-page{display:flex;flex-direction:column;gap:20px;padding:8px 0 32px}.progress-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;padding-bottom:8px;border-bottom:1px solid var(--border)}.progress-header h1{margin:6px 0 2px;font-size:22px;font-weight:700}.progress-title{font-size:22px;font-weight:700;margin:6px 0 2px;color:var(--text)}.progress-subtitle{margin:0;color:var(--text-muted);font-size:13px}.progress-meta{display:flex;flex-direction:column;align-items:flex-end;gap:6px;font-size:12px;color:var(--text-muted)}.progress-refresh{font-variant-numeric:tabular-nums;color:var(--text-muted);font-size:12px}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm, 6px);padding:18px 20px;display:flex;flex-direction:column;gap:14px}.progress-section-title{font-size:16px;font-weight:700;color:var(--text);margin:0}.progress-user-list{display:flex;flex-direction:column;gap:14px}.progress-user-row{display:grid;grid-template-columns:200px 1fr;gap:16px;align-items:center;padding:12px 14px;background:var(--bg-elevated, var(--surface));border:1px solid var(--border);border-radius:var(--radius-sm, 6px)}.progress-user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.progress-user-name{font-size:14px;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-user-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-user-bar-wrap{display:flex;flex-direction:column;gap:6px}.progress-user-bar{position:relative;background:var(--code-bg, rgba(15, 23, 42, .06));border-radius:999px;height:22px;overflow:hidden}.progress-user-bar-fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,var(--primary),var(--primary-hover, var(--primary)));transition:width var(--transition-medium, .25s ease)}.progress-user-bar-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text);mix-blend-mode:difference}.progress-user-counts{display:flex;gap:12px;font-size:11px;color:var(--text-muted);flex-wrap:wrap}.progress-count-done:before{content:"✓";color:var(--success, #059669);font-weight:700}.progress-count-progress:before{content:"•";color:var(--primary);font-weight:700}.progress-count-pending:before{content:"○";color:var(--text-muted)}.progress-empty{margin:0;color:var(--text-muted);font-size:13px;font-style:italic}.progress-kappa-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap}.progress-kappa-note{font-size:12px;color:var(--text-muted);font-style:italic}.progress-fleiss{display:flex;align-items:center;gap:18px;padding:16px 18px;background:var(--bg-elevated, var(--surface));border:1px solid var(--border);border-radius:var(--radius-sm, 6px);flex-wrap:wrap}.progress-fleiss-value{font-size:42px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--primary);line-height:1}.progress-fleiss-meta{display:flex;flex-direction:column;gap:6px;flex:1;min-width:200px}.progress-fleiss-detail{font-size:12px;color:var(--text-muted)}.progress-fleiss-error{font-size:13px;color:var(--text-muted);font-style:italic}.progress-kappa-badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.kappa-empty,.kappa-bad{background:#78787826;color:var(--text-muted)}.kappa-poor{background:#d6454526;color:#b91c1c}.kappa-fair{background:#eab3082e;color:#a16207}.kappa-moderate{background:#eab3084d;color:#854d0e}.kappa-substantial{background:#0596692e;color:#047857}.kappa-almost-perfect{background:#05966952;color:#065f46}.progress-subtitle-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:6px 0 -4px}.progress-pairwise{display:flex;flex-direction:column;gap:6px}.progress-pair-row{display:grid;grid-template-columns:1fr 90px 2fr;gap:14px;align-items:center;padding:10px 12px;background:var(--bg-elevated, var(--surface));border:1px solid var(--border);border-radius:var(--radius-sm, 6px);font-size:13px}.progress-pair-names{display:flex;align-items:center;gap:8px;font-weight:600}.progress-pair-user{color:var(--text)}.progress-pair-vs{color:var(--text-muted);font-weight:400}.progress-pair-value{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums;text-align:center;padding:4px 0;border-radius:6px}.progress-pair-detail{font-size:12px;color:var(--text-muted)}.kappa-matrix-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm, 6px)}.kappa-matrix{width:100%;border-collapse:collapse;font-size:12px}.kappa-matrix th,.kappa-matrix td{padding:8px 10px;text-align:center;border-bottom:1px solid var(--border);border-right:1px solid var(--border)}.kappa-matrix th{background:var(--bg-elevated, var(--surface));font-weight:700;font-size:11px;text-transform:lowercase;color:var(--text-muted);white-space:nowrap;max-width:110px;overflow:hidden;text-overflow:ellipsis}.kappa-matrix th:first-child{background:transparent;border-right:2px solid var(--border)}.kappa-matrix tr:last-child td{border-bottom:none}.kappa-matrix td:last-child{border-right:none}.kappa-cell{font-variant-numeric:tabular-nums;font-weight:600}.progress-footer-note{font-size:12px;color:var(--text-muted);text-align:center;margin:0}@media (max-width: 720px){.progress-user-row{grid-template-columns:1fr}.progress-pair-row{grid-template-columns:1fr;gap:4px}.progress-pair-value{text-align:left}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px;padding:0}.page-header h2{font-size:28px;font-weight:800;letter-spacing:-.03em;color:var(--primary)}.hero-section{margin:-28px -24px 20px;padding:28px 24px;background:linear-gradient(180deg,var(--primary-soft) 0%,var(--bg) 100%);border-bottom:1px solid var(--border)}.hero-content{max-width:1100px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}.hero-title{font-size:32px;font-weight:900;letter-spacing:-.04em;color:var(--primary);line-height:1.1}.hero-subtitle{font-size:15px;font-weight:600;color:var(--text);letter-spacing:-.01em}.hero-text{font-size:14px;color:var(--text-secondary);line-height:1.6;max-width:760px}@media (max-width: 640px){.hero-section{padding:22px 16px;margin-bottom:16px}.hero-title{font-size:26px}.hero-subtitle{font-size:14px}.hero-text{font-size:13px}}.table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.table th,.table td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--border)}.table th{background:var(--surface-alt);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover{background:#fafbfe}.actions-cell{display:flex;gap:8px;white-space:nowrap}.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.03em;color:#fff}.badge-absa{background:var(--absa)}.badge-asqp{background:var(--asqp)}.badge-ssa{background:var(--ssa)}.progress-bar{height:7px;background:var(--surface-alt);border-radius:4px;overflow:hidden;margin-bottom:4px;min-width:120px}.progress-bar-fill{height:100%;background:var(--success);border-radius:4px;transition:width .3s}.help-box{margin-top:28px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow)}.help-box h3{font-size:15px;margin-bottom:10px}.help-box ul{list-style:none;display:flex;flex-direction:column;gap:6px}.help-box li{font-size:14px;color:var(--text-muted)}.upload-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px 24px;margin-bottom:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:16px}.upload-card h3{font-size:17px;margin-bottom:2px}.upload-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.upload-actions{display:flex;gap:10px;justify-content:flex-end}.upload-hint{font-size:12px;color:var(--text-muted)}.upload-hint-task{display:flex;flex-direction:column;gap:8px;padding:12px 14px;background:var(--bg-elevated, var(--surface));border:1px solid var(--border);border-radius:var(--radius-sm, 6px)}.upload-hint-task-header{font-size:12px;color:var(--text-muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}.upload-hint-task-header strong{color:var(--text);font-weight:600}.upload-format-example{margin:0;padding:10px 12px;background:var(--code-bg, rgba(15, 23, 42, .04));border-radius:4px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:12px;line-height:1.45;overflow-x:auto;white-space:pre;color:var(--text);border:1px solid var(--border)}.upload-format-notes{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-muted)}.upload-format-notes code{background:var(--code-bg, rgba(15, 23, 42, .06));padding:1px 5px;border-radius:3px;font-size:11px}.upload-filezone{border:1px dashed var(--border);border-radius:var(--radius-sm, 6px);background:var(--bg-elevated, var(--surface));transition:border-color var(--transition-fast, .15s ease),background var(--transition-fast, .15s ease)}.upload-file-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:28px 16px;cursor:pointer;text-align:center;color:var(--text-muted)}.upload-file-drop:hover{color:var(--text)}.upload-file-drop-title{font-size:14px;font-weight:500}.upload-file-drop-sub{font-size:12px}.upload-file-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);clip:rect(0,0,0,0);white-space:nowrap;border:0}.upload-file-loaded{display:flex;align-items:center;gap:12px;padding:14px 16px}.upload-file-icon{font-size:22px;line-height:1}.upload-file-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.upload-file-name{font-size:14px;font-weight:500;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file-meta{font-size:12px;color:var(--text-muted)}.annotate-top{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px;flex-wrap:wrap}.annotate-top h2{font-size:22px;font-weight:800;display:flex;align-items:center;gap:10px;letter-spacing:-.02em}.annotate-nav{display:flex;align-items:center;gap:10px}.annotate-counter{font-size:13px;font-weight:700;color:var(--text-muted);min-width:90px;text-align:center;background:var(--surface-alt);padding:6px 12px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.04em}.annotate-grid{display:grid;grid-template-columns:1fr minmax(260px,340px);gap:22px;align-items:start}@media (max-width: 880px){.annotate-grid{grid-template-columns:1fr}}.text-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.text-panel-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:14px;display:flex;align-items:center;gap:8px}.text-panel-label:before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--primary)}.text-display{font-size:16px;line-height:1.85;word-spacing:.06em;white-space:pre-wrap;word-break:break-word;padding:20px 22px;background:var(--surface-alt);border-radius:var(--radius-sm);border:1px solid var(--border);min-height:100px;-webkit-user-select:text;user-select:text;color:var(--text)}.text-meta{display:flex;gap:16px;margin-top:16px;font-size:13px;color:var(--text-muted);flex-wrap:wrap}.text-meta strong{color:var(--text)}.editor-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px 26px;display:flex;flex-direction:column;gap:14px;width:100%}.editor-panel h3{font-size:14px;display:flex;align-items:center;justify-content:space-between;margin-bottom:0}.annot-list{display:flex;flex-direction:column;gap:8px}.annot-row{border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;background:var(--surface-alt);display:flex;flex-direction:column;gap:8px;font-size:13px;max-width:720px}.annot-row-head{display:flex;align-items:center;justify-content:space-between;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.annot-row-head .row-actions{display:flex;gap:6px}.annot-row-head .row-actions .btn{padding:4px 8px;font-size:11px;min-height:26px}.annot-fields{display:grid;grid-template-columns:1fr 1fr;gap:8px}.annot-fields label{font-size:11px}.annot-field-full{grid-column:1 / -1}.polarity-pills{display:flex;gap:6px}.pill{flex:1;padding:4px 0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:12px;font-weight:600;cursor:pointer;text-align:center;transition:all .15s;color:var(--text)}.pill:hover{border-color:var(--primary)}.pill.active.pos{background:var(--success);color:#fff;border-color:var(--success)}.pill.active.neg{background:var(--danger);color:#fff;border-color:var(--danger)}.pill.active.neu{background:var(--text-muted);color:#fff;border-color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);font-size:14px;padding:20px 8px;border:1px dashed var(--border-strong);border-radius:var(--radius-sm)}.editor-footer{display:flex;gap:10px;justify-content:space-between;border-top:1px solid var(--border);padding-top:14px}.editor-footer .nav-group{display:flex;gap:8px}.status-badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:700}.status-pending{background:var(--surface-alt);color:var(--text-muted)}.status-in_progress{background:#fff3bf;color:#9a6b00}.status-done{background:#e8f6ee;color:var(--success)}.hl-aspect{background:#d6e4ff}.word-token.hl-aspect{background:#d6e4ff99}.hl-sentiment{background:#ffe0b3}.word-token.hl-sentiment{background:#ffe0b399}.hl-holder{background:#d6f5e0}.word-token.hl-holder{background:#d6f5e099}.word-token{cursor:pointer;border-radius:3px;padding:1px;transition:outline .12s,background .12s}.word-token:hover{outline:1.5px solid var(--primary);outline-offset:0}.word-token.marked{text-decoration:underline;text-decoration-style:dashed;text-decoration-thickness:2px;text-underline-offset:3px;font-weight:600}.text-canvas-wrap{position:relative}.tag-popover{position:fixed;z-index:50;transform:translate(-50%,-110%);background:var(--text);color:#fff;border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);padding:8px;min-width:180px}.tag-popover-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;opacity:.7;padding:2px 6px 6px}.tag-popover-list{display:flex;flex-direction:column;gap:2px}.tag-popover-item{display:flex;align-items:center;gap:8px;width:100%;text-align:left;background:transparent;border:none;color:#fff;padding:8px 10px;border-radius:5px;cursor:pointer;font-size:14px;font-weight:600}.tag-popover-item:hover{background:#ffffff24}.tag-popover-filled{margin-left:auto;font-size:10px;font-weight:600;opacity:.6;font-style:italic}.tag-dot{width:11px;height:11px;border-radius:50%;background:var(--border-strong);flex-shrink:0;display:inline-block}.tag-dot.hl-aspect{background:#5b8cff}.tag-dot.hl-sentiment{background:#e8a23a}.tag-dot.hl-holder{background:#4fc478}.tag-dot.hl-pos{background:#2e9e5b}.tag-dot.hl-neg{background:#d64545}.tag-dot.hl-neu{background:#9aa3b2}.hl-pos{background:#c8f0d8}.word-token.hl-pos{background:#c8f0d899}.hl-neg{background:#f5cdcd}.word-token.hl-neg{background:#f5cdcd99}.hl-neu{background:#e4e7ee}.word-token.hl-neu{background:#e4e7ee99}.slot-chip.hl-pos{background:#e8f6ee;border-color:#aee3c4;color:#1d7a44}.slot-chip.hl-neg{background:#fdeaea;border-color:#f2c9c9;color:#b83636}.slot-chip.hl-neu{background:#eef0f5;border-color:#d4d9e3;color:#6b7689}.hl-mixed{background:repeating-linear-gradient(135deg,#f5cdcd 0,#f5cdcd 6px,#c8f0d8 6px,#c8f0d8 12px)}.word-token.hl-mixed{background:repeating-linear-gradient(135deg,#f5cdcd99 0,#f5cdcd99 6px,#c8f0d899 6px,#c8f0d899 12px)}.tag-dot.hl-mixed{background:repeating-linear-gradient(135deg,#d64545 0,#d64545 5px,#2e9e5b 5px,#2e9e5b 10px)}.word-token.border-hl-aspect{box-shadow:inset 0 -2px #5b8cff}.word-token.border-hl-sentiment{box-shadow:inset 0 -2px #e8a23a}.word-token.border-hl-holder{box-shadow:inset 0 -2px #4fc478}.tag-dot.border-hl-aspect{background:#fff;border:2px solid #5b8cff}.tag-dot.border-hl-sentiment{background:#fff;border:2px solid #e8a23a}.tag-dot.border-hl-holder{background:#fff;border:2px solid #4fc478}.tag-legend-sep{width:1px;height:18px;background:var(--border-strong);margin:0 4px}.absa-row{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;background:var(--surface-alt);display:flex;flex-direction:column;gap:10px}.absa-row-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.absa-row-head .slot-chip{font-size:14px;padding:4px 12px}.absa-row.absa-draft{border:2px dashed var(--primary);background:var(--primary-soft, rgba(15, 118, 110, .06));box-shadow:0 0 0 3px #0f766e14}.absa-draft-tag{margin-left:auto;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:999px;background:var(--primary);color:#fff;white-space:nowrap}.absa-draft-actions{display:flex;justify-content:flex-end;margin-top:2px}.tag-legend{display:flex;align-items:center;flex-wrap:wrap;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:9px 14px;margin-bottom:16px;font-size:13px}.tag-legend-title{font-weight:700;color:var(--text-muted);text-transform:uppercase;font-size:11px;letter-spacing:.04em}.tag-legend-item{display:inline-flex;align-items:center;gap:5px;color:var(--text);font-weight:500}.tag-legend-item em{color:var(--text-muted);font-style:italic;font-weight:400}.section-title{font-size:14px;font-weight:700;margin-bottom:10px}.row-actions{display:flex;gap:6px}.tuple-slots{display:flex;flex-wrap:nowrap;gap:16px}.tuple-slots>.tuple-slot{flex:1 1 0;min-width:0}.tuple-slots.compact{display:flex;flex-wrap:nowrap;gap:8px}.tuple-slots.compact>.tuple-slot{flex:1 1 0;min-width:0}.tuple-slots.compact .slot-chip,.tuple-slots.compact .slot-value{max-width:220px}.tuple-slot{display:flex;flex-direction:column;gap:4px;min-width:0;overflow:hidden}.tuple-slot .slot-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted)}.slot-chip,.slot-value{display:inline-block;max-width:100%;padding:3px 8px;border-radius:12px;font-size:12px;font-weight:600;background:var(--surface);border:1px solid var(--border);color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;box-sizing:border-box}.slot-chip.hl-aspect{background:#eef4ff;border-color:#b9cdff}.slot-chip.hl-sentiment{background:#fff3df;border-color:#f0d39a}.slot-chip.hl-holder{background:#eafaf0;border-color:#aee3c4}.slot-chip.missing{background:#fff7e6;border:1px dashed #e8c46a;font-style:italic;font-weight:600;color:var(--warning)}.tuple-slot.missing .slot-label{color:var(--warning)}.annot-row.incomplete{border-color:#e8c46a;background:#fffdf6}.incomplete-badge{font-size:12px;color:#9a6b00;background:#fff3df;border-radius:var(--radius-sm);padding:6px 10px;margin-bottom:8px}.tuple-draft{display:flex;flex-direction:column;gap:10px;max-width:960px}.tuple-draft-head{display:flex;align-items:center;justify-content:space-between}.tuple-draft-head h4{font-size:15px;font-weight:700}.tuple-slot.build{padding:8px 10px;border-left:3px solid var(--border);background:var(--surface-alt);border-radius:var(--radius-sm)}.tuple-slot.build.category{border-left-color:#c4b5fd;background:#f5f3ff}.tuple-slot.build.aspect{border-left-color:#bfdbfe;background:#eff6ff}.tuple-slot.build.sentiment{border-left-color:#fde68a;background:#fffbeb}.tuple-slot.build.polarity{border-left-color:#a7f3d0;background:#ecfdf5}.tuple-slot.build.holder{border-left-color:#a5f3fc;background:#ecfeff}.tuple-slot.build .opt-tag{margin-left:6px;font-size:10px;font-weight:600;color:var(--text-muted);font-style:italic;text-transform:none}.slot-filled{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.slot-empty{font-size:12px;color:var(--text-muted);font-style:italic;padding:2px 0}.no-holder-btn{margin-left:8px;font-style:normal;vertical-align:middle}.slot-chip.no-holder{background:#eef0f5;border:1px solid #c9d0dd;color:var(--text-muted);font-style:italic}.slot-clear{border:none;background:var(--danger-soft);color:var(--danger);width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:15px;line-height:1;display:flex;align-items:center;justify-content:center;flex-shrink:0}.slot-clear:hover{background:var(--danger);color:#fff}.slot-type-select{width:auto;font-size:12px;padding:4px 8px}.tuple-slot select{width:auto;max-width:100%;align-self:flex-start}.tuple-add-btn{width:100%;margin-top:4px}.task-sections{display:flex;flex-direction:column;gap:24px}.task-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}.task-section-header{display:flex;align-items:center;gap:14px;padding:20px 24px;background:linear-gradient(90deg,var(--primary-soft) 0%,rgba(255,247,237,.6) 100%);border-bottom:1px solid var(--border)}.task-section-header h3{font-size:17px;font-weight:700;color:var(--text);flex:1}.task-count{font-size:12px;font-weight:600;color:var(--text-muted);background:var(--surface);padding:4px 10px;border-radius:var(--radius-pill);border:1px solid var(--border)}.task-empty{padding:24px 22px;color:var(--text-muted);font-size:14px;font-style:italic}.task-dataset-list{display:flex;flex-direction:column;gap:12px;padding:18px 22px}.task-dataset-card{display:grid;grid-template-columns:1fr auto;gap:12px 16px;padding:16px 18px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.task-dataset-card:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md)}.task-dataset-main{display:flex;flex-direction:column;gap:8px;min-width:0}.task-dataset-name{font-size:15px;font-weight:700;color:var(--primary);text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-dataset-name:hover{text-decoration:underline}.task-dataset-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-muted);flex-wrap:wrap}.task-dataset-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.task-dataset-progress{grid-column:1 / -1;display:flex;align-items:center;gap:12px}.task-dataset-pct{font-size:12px;font-weight:700;color:var(--text-muted);min-width:36px;text-align:right}.task-guide{border-top:1px solid var(--border);background:linear-gradient(180deg,#fbfbfd 0%,var(--surface) 100%)}.task-guide-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border:none;background:transparent;font-size:15px;font-weight:700;color:var(--text);cursor:pointer;transition:background-color .15s ease}.task-guide-toggle:hover{background-color:#3b6fe00f}.task-guide-chevron{color:var(--text-muted);font-size:14px}.task-guide-content{padding:0 22px;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s ease,opacity .5s ease,padding .5s ease}.task-guide-content-open{padding:0 22px 18px;max-height:2000px;opacity:1}.task-guide-content h4{font-size:15px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:8px}.task-guide-content h4:before{content:"";display:inline-block;width:6px;height:20px;background:var(--ssa);border-radius:3px}.task-guide-section{margin-bottom:16px}.task-guide-section:last-child{margin-bottom:0}.task-guide-section h5{font-size:13px;font-weight:700;color:var(--text-secondary);margin-bottom:6px}.task-guide-section p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin-bottom:8px}.task-guide-section ul{list-style:disc;padding-left:20px;display:flex;flex-direction:column;gap:8px}.task-guide-section li{font-size:13px;line-height:1.5;color:var(--text-secondary)}.task-guide-example{background:var(--surface-alt);border-left:3px solid var(--ssa);padding:10px 14px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:13px;color:var(--text-secondary);font-style:italic}@media (max-width: 640px){.task-dataset-card{grid-template-columns:1fr}.task-dataset-actions{justify-content:flex-start}.task-dataset-progress{order:3}}.annotate-layout{display:flex;flex-direction:row;min-height:calc(100vh - 64px);gap:0}.annotate-workspace{display:flex;flex-direction:column;flex:1 1 auto;min-width:0;min-height:0;overflow:hidden}.annotate-canvas-area{flex:1 1 auto;min-height:0;overflow-y:auto}.annotate-main{flex:1 1 auto;min-width:0;padding:24px 28px 0;min-height:0}.ai-assist-panel{position:sticky;bottom:0;background:var(--surface);border-top:1px solid var(--border);margin:24px -28px 0;padding:16px 28px;z-index:1}.item-strip{display:flex;flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:8px;padding:6px 0 10px;background:transparent;border:none;border-bottom:1px solid var(--border);border-radius:0;box-shadow:none;flex:0 0 auto;min-height:0;margin-bottom:14px}.item-strip-search{align-self:flex-start;font-size:13px;padding:5px 10px;max-width:280px}.item-strip.collapsed{width:auto;min-width:54px;min-height:54px}.item-strip-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;min-height:54px}.item-strip-header .section-title{margin:0;font-size:15px}.item-strip-toggle{width:28px;height:28px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-weight:700;border-radius:var(--radius-sm)}.item-strip-tabs{display:flex;flex:0 0 auto;gap:4px;padding:0;background:transparent;border-bottom:none;flex-wrap:wrap}.item-strip-tab{flex:0 0 auto;border:1px solid var(--border);background:var(--surface);color:var(--text-secondary);font-size:12px;font-weight:600;padding:6px 10px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast);white-space:nowrap}.item-strip-tab:hover{background:var(--surface-alt);color:var(--text)}.item-strip-tab.active{background:var(--primary-soft);border-color:var(--border-strong);color:var(--primary);box-shadow:var(--shadow)}.item-strip-list{flex:0 1 auto;min-width:0;display:flex;align-items:flex-start;flex-wrap:wrap;gap:5px;padding:0;overflow-y:auto;overflow-x:hidden;max-height:96px}.item-strip-header-row{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.item-strip-search{width:100%;max-width:220px;padding:5px 10px 5px 30px;font-size:13px;line-height:1.4;background-color:var(--surface);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.3-4.3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:9px center;background-size:14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.item-strip-search:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.item-strip-search::placeholder{color:var(--text-muted)}.item-chip{padding:5px 9px;gap:8px}.item-strip-empty{padding:6px 8px;text-align:center;color:var(--text-muted);font-size:13px}.item-chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:10px;text-align:left;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);white-space:nowrap}.item-chip:hover{border-color:var(--border-strong);background:var(--surface-alt)}.item-chip.current{border-color:var(--border-strong);background:var(--primary-soft)}.item-chip-number{font-size:12px;font-weight:700;color:var(--text-muted);min-width:24px}.item-chip.current .item-chip-number{color:var(--primary)}.item-chip-id{font-size:13px;color:var(--text-secondary);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.item-chip .status-dot{flex:0 0 auto;width:10px;height:10px;border-radius:50%;padding:0;min-width:10px;background:var(--text-muted)}.item-chip .status-dot.status-done{background:var(--success)}.item-chip .status-dot.status-in_progress{background:var(--warning)}.item-chip .status-dot.status-pending{background:var(--text-muted)}.item-strip-footer{display:flex;flex:0 0 auto;flex-direction:row;align-items:center;justify-content:space-between;gap:10px;padding:10px 0 0;background:transparent;border-top:1px solid var(--border);border-left:none}.item-strip-footer-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.item-strip-count{font-size:12px;font-weight:600;color:var(--text-muted)}.item-strip-pagination{display:flex;align-items:center;gap:6px}@media (max-width: 720px){.annotate-layout{flex-direction:column}.item-strip{border-radius:var(--radius)}.annotate-main{padding:16px 16px 0}.ai-assist-panel{margin:16px -16px 0;padding:12px 16px}}.sentence{cursor:pointer}.word-token{cursor:text}.sentence .word-token{cursor:pointer}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--modal-overlay-bg);display:flex;align-items:center;justify-content:center;z-index:1100;padding:16px}.modal-content{background-color:var(--surface);border-radius:10px;box-shadow:0 10px 30px #1018281f;width:100%;max-width:560px;max-height:calc(100vh - 32px);display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h3{margin:0;font-size:17px}.modal-close{background:transparent;border:none;font-size:24px;line-height:1;color:var(--text-muted);cursor:pointer}.modal-close:hover{color:var(--text)}.modal-body{padding:20px;overflow-y:auto}.invite-form{margin-bottom:20px}.invite-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}.invite-field{display:flex;flex-direction:column;gap:4px;flex:1 1 220px}.invite-field-user{position:relative;flex:2 1 280px}.invite-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text)}.invite-row input{padding:8px 10px;border:1px solid var(--border-strong);border-radius:6px;font-size:14px;width:100%}.invite-row input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.invite-help{font-size:11px;color:var(--text-muted);line-height:1.3}.invite-submit{display:flex;align-items:flex-end}.invite-row .btn{white-space:nowrap}.member-tabs{display:flex;gap:4px;background-color:var(--surface-alt);padding:4px;border-radius:8px;margin-bottom:20px}.member-tab{flex:1;padding:8px 12px;border:none;border-radius:6px;background:transparent;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s ease}.member-tab:hover{color:var(--text);background-color:#ffffff80}.member-tab.active{background-color:var(--surface);color:var(--primary);box-shadow:0 1px 2px #10182814}.member-list{list-style:none;margin:0;padding:0}.member-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--border);border-radius:6px;margin-bottom:8px}.member-info{display:flex;flex-direction:column;gap:2px}.member-name{font-weight:700;font-size:14px}.member-email{font-size:12px;color:var(--text-muted)}.member-meta{display:flex;align-items:center;gap:10px}.member-deadline{font-size:12px;color:var(--text-muted)}.member-empty{color:var(--text-muted);font-size:14px}.form-success{background-color:#e6f4ed;color:var(--success);padding:8px 12px;border-radius:6px;margin-top:8px;font-size:13px}.btn-members{display:inline-flex;align-items:center;gap:6px;background-color:var(--primary-soft);border-color:var(--primary-soft);color:var(--primary);font-weight:600}.btn-members:hover{background-color:var(--primary);border-color:var(--primary);color:#fff}.btn-members svg{opacity:.9}.members-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background-color:var(--primary);color:#fff;font-size:11px;font-weight:700}.members-page{max-width:900px;margin:0 auto}.members-page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px}.members-page-header h1{margin:8px 0 4px;font-size:24px}.members-back-link{display:inline-block;font-size:13px;color:var(--primary);text-decoration:none;font-weight:600;margin-bottom:4px}.members-back-link:hover{text-decoration:underline}.members-task-type{display:inline-block;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.members-page-card{background-color:var(--surface);border:1px solid var(--border);border-radius:10px;padding:24px;box-shadow:0 1px 3px #10182814}.annotate-tabs{display:flex;gap:4px;background-color:var(--surface-alt);padding:4px;border-radius:8px;margin:0 16px}.annotate-tab{padding:7px 14px;border-radius:6px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:all .15s ease}.annotate-tab:hover{color:var(--text);background-color:#ffffff80}.annotate-tab.active{background-color:var(--surface);color:var(--primary);box-shadow:0 1px 2px #10182814}.notification-bell{position:relative;display:inline-block}.notification-bell-toggle{background:#fff;border:1px solid var(--border-strong);color:var(--text);cursor:pointer;padding:8px;border-radius:10px;display:flex;align-items:center;justify-content:center;position:relative;transition:all .15s ease;box-shadow:0 1px 2px #1018280d}.notification-bell-toggle:hover{background-color:var(--primary-soft);border-color:var(--primary);color:var(--primary)}.notification-bell-toggle:active{transform:scale(.96)}.notification-bell-badge{position:absolute;top:2px;right:2px;background-color:var(--danger);color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 2px #00000026}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:380px;max-width:calc(100vw - 24px);background-color:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:0 10px 30px #1018281f;z-index:1000;overflow:hidden}.notification-dropdown-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);font-weight:700;font-size:15px}.notification-dropdown-header .btn{padding:4px 8px;font-size:12px}.notification-list{list-style:none;margin:0;padding:0;max-height:440px;overflow-y:auto}.notification-item{padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background-color .15s ease}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:var(--surface-alt)}.notification-unread{background-color:var(--primary-soft)}.notification-unread:hover{background-color:#dbe5f9}.notification-read{opacity:.85}.notification-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.notification-type{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 7px;border-radius:4px}.notification-type-invite{background-color:var(--primary-soft);color:var(--primary)}.notification-type-invite_accepted{background-color:#e6f4ed;color:var(--success)}.notification-type-invite_rejected{background-color:#fdecec;color:var(--danger)}.notification-type-deadline_reminder{background-color:#fdf3e3;color:var(--warning)}.notification-type-completion{background-color:#e6f4ed;color:var(--success)}.notification-date{font-size:11px;color:var(--text-muted)}.notification-title{font-weight:700;font-size:14px;margin-bottom:4px;color:var(--text)}.notification-message{font-size:13px;color:var(--text-muted);line-height:1.4;margin-bottom:10px}.notification-item-actions{display:flex;gap:8px}.notification-item-actions .btn{padding:4px 10px;font-size:12px}.notification-empty{padding:28px 16px;text-align:center;color:var(--text-muted);font-size:14px}.notification-error{margin:8px;padding:8px;font-size:12px}.invite-user-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:var(--surface);border:1px solid var(--border-strong);border-radius:8px;box-shadow:0 10px 30px #1018281f;z-index:100;max-height:240px;overflow-y:auto}.invite-user-list{list-style:none;margin:0;padding:4px}.invite-user-option{width:100%;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:none;background:transparent;border-radius:6px;cursor:pointer;text-align:left;font-size:14px;color:var(--text)}.invite-user-option:hover{background-color:var(--primary-soft)}.invite-user-name{font-weight:600}.invite-user-email{font-size:12px;color:var(--text-muted)}.invite-user-empty{padding:12px;font-size:13px;color:var(--text-muted);text-align:center}.profile-card{display:flex;align-items:flex-start;gap:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}.profile-photo-wrapper{display:flex;flex-direction:column;align-items:center;gap:12px}.profile-photo,.profile-avatar{width:96px;height:96px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.profile-avatar{display:flex;align-items:center;justify-content:center;background:var(--primary-soft);color:var(--primary);font-size:40px;font-weight:800}.profile-photo-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.profile-info{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:14px}.profile-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-name-row h3{font-size:22px;font-weight:800;color:var(--text);margin:0}.profile-email{font-size:15px;color:var(--text-secondary);margin:0}.profile-meta{display:flex;gap:8px;flex-wrap:wrap}.profile-edit{display:flex;flex-direction:column;gap:10px;max-width:320px}.profile-edit label{font-size:13px;font-weight:700;color:var(--text-secondary)}.profile-edit input{padding:10px 12px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:15px}.profile-edit-actions{display:flex;gap:8px}.settings-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);max-width:560px}.settings-card h3{font-size:16px;font-weight:800;color:var(--text);margin:0 0 20px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 0;border-bottom:1px solid var(--border)}.setting-row:last-of-type{border-bottom:none}.setting-text{display:flex;flex-direction:column;gap:4px}.setting-title{font-size:14px;font-weight:700;color:var(--text)}.setting-desc{font-size:13px;color:var(--text-secondary)}.settings-actions{display:flex;align-items:center;gap:12px;margin-top:20px}.settings-saved{font-size:13px;font-weight:700;color:var(--success)}.toggle{position:relative;display:inline-block;width:44px;height:24px;flex:0 0 44px;cursor:pointer}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:999px;transition:background-color var(--transition-fast)}.toggle-slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--surface);border-radius:50%;transition:transform var(--transition-fast);box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(20px)}.toggle input:focus-visible+.toggle-slider{outline:2px solid var(--primary);outline-offset:2px}@media (max-width: 480px){.profile-card{flex-direction:column;align-items:center;text-align:center}.profile-name-row,.profile-meta{justify-content:center}.setting-row{align-items:flex-start;flex-direction:column}}.help-page{display:flex;flex-direction:column;gap:24px}.help-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 900px){.help-grid{grid-template-columns:1.2fr 1fr}}.help-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:22px}.help-card-header{display:flex;align-items:flex-start;gap:14px}.help-card-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--primary-soft);border-radius:var(--radius);font-size:22px;flex:0 0 44px}.help-card h3{font-size:18px;font-weight:800;color:var(--text);margin:0 0 4px}.help-card p{font-size:14px;color:var(--text-secondary);margin:0}.help-task-list{display:flex;flex-direction:column;gap:12px}.help-task-card{display:flex;align-items:center;gap:14px;padding:18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;text-align:left;transition:background-color var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast)}.help-task-card:hover{background:var(--surface-alt);border-color:var(--primary);transform:translateY(-1px)}.help-task-card:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.help-task-card--absa{border-left:4px solid var(--absa)}.help-task-card--asqp{border-left:4px solid var(--asqp)}.help-task-card--ssa{border-left:4px solid var(--ssa)}.help-task-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--surface-alt);border-radius:50%;font-size:20px;flex:0 0 40px}.help-task-content{flex:1 1 auto;display:flex;flex-direction:column;gap:4px}.help-task-content strong{font-size:15px;font-weight:700;color:var(--text)}.help-task-content span{font-size:13px;color:var(--text-secondary);line-height:1.45}.help-task-arrow{font-size:18px;color:var(--text-muted);font-weight:700}.help-task-card:hover .help-task-arrow{color:var(--primary)}.help-tips{list-style:none;display:flex;flex-direction:column;gap:14px;margin:0;padding:0}.help-tips li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text);line-height:1.55}.help-tip-bullet{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--success-soft);color:var(--success);border-radius:50%;font-size:12px;font-weight:700;flex:0 0 20px;margin-top:1px}.ai-suggestions-actions{display:flex;justify-content:flex-end;margin-top:14px;padding-top:12px;border-top:1px solid var(--border)}.ai-suggestions-button{min-width:150px}.ai-suggestions-button .ai-suggestions-spinner{width:14px;height:14px;border-width:2px}
