:root{--primary-50: #e3f2fd;--primary-100: #bbdefb;--primary-200: #90caf9;--primary-300: #64b5f6;--primary-400: #42a5f5;--primary-500: #1976d2;--primary-600: #1565c0;--primary-700: #0d47a1;--secondary-500: #9c27b0;--success-50: #e8f5e9;--success-500: #2e7d32;--success-600: #1b5e20;--warning-50: #fff8e1;--warning-500: #ed6c02;--error-50: #fbe9e7;--error-500: #d32f2f;--error-600: #c62828;--info-50: #e1f5fe;--info-500: #0288d1;--grey-50: #fafafa;--grey-100: #f5f5f5;--grey-200: #eeeeee;--grey-300: #e0e0e0;--grey-400: #bdbdbd;--grey-500: #9e9e9e;--grey-600: #757575;--grey-700: #616161;--grey-800: #424242;--grey-900: #212121;--background: #f5f7fa;--surface: #ffffff;--surface-variant: #f8f9fb;--on-surface: var(--grey-900);--on-surface-secondary: var(--grey-600);--border-color: var(--grey-300);--divider: var(--grey-200);--elevation-1: 0 2px 1px -1px rgba(0,0,0,.06), 0 1px 1px 0 rgba(0,0,0,.04), 0 1px 3px 0 rgba(0,0,0,.04);--elevation-2: 0 3px 3px -2px rgba(0,0,0,.06), 0 3px 4px 0 rgba(0,0,0,.04), 0 1px 8px 0 rgba(0,0,0,.04);--elevation-3: 0 3px 5px -1px rgba(0,0,0,.06), 0 6px 10px 0 rgba(0,0,0,.04), 0 1px 18px 0 rgba(0,0,0,.04);--elevation-4: 0 5px 5px -3px rgba(0,0,0,.06), 0 8px 10px 1px rgba(0,0,0,.04), 0 3px 14px 2px rgba(0,0,0,.04);--font-family: "Open Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width: 220px;--sidebar-collapsed-width: 68px;--status-bar-height: 40px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;color-scheme:light}body{font-family:var(--font-family);background:var(--background);color:var(--on-surface);line-height:1.5;min-height:100vh}h1{font-size:2rem;font-weight:700;line-height:1.2;letter-spacing:-.5px}h2{font-size:1.5rem;font-weight:600;line-height:1.3}h3{font-size:1.25rem;font-weight:600;line-height:1.4}h4{font-size:1rem;font-weight:600;line-height:1.4}.subtitle1{font-size:1rem;font-weight:500;color:var(--on-surface-secondary)}.subtitle2{font-size:.875rem;font-weight:500;color:var(--on-surface-secondary)}.body2{font-size:.875rem}.caption{font-size:.75rem;color:var(--on-surface-secondary)}.overline{font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--on-surface-secondary)}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-700);text-decoration:underline}.app-shell{display:flex;min-height:100vh}.page-content{padding:var(--space-6);flex:1;padding-bottom:calc(var(--status-bar-height) + var(--space-6))}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4);flex-wrap:wrap}.page-header-text h1{margin-bottom:var(--space-1)}.card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);box-shadow:var(--elevation-1);overflow:hidden}.card-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--divider);display:flex;align-items:center;justify-content:space-between}.card-body{padding:var(--space-5)}.card-footer{padding:var(--space-3) var(--space-5);border-top:1px solid var(--divider);background:var(--surface-variant);display:flex;justify-content:space-between;align-items:center}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-family:var(--font-family);font-size:.875rem;font-weight:600;line-height:1.5;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none;-webkit-user-select:none;user-select:none}.btn i{font-size:18px}.btn-primary{background:var(--primary-500);color:#fff}.btn-primary:hover{background:var(--primary-600)}.btn-secondary{background:transparent;color:var(--primary-500);border:1px solid var(--primary-500)}.btn-secondary:hover{background:var(--primary-50)}.btn-ghost{background:transparent;color:var(--on-surface-secondary)}.btn-ghost:hover{background:var(--grey-100);color:var(--on-surface)}.btn-danger{background:var(--error-500);color:#fff}.btn-danger:hover{background:var(--error-600)}.btn-success{background:var(--success-500);color:#fff}.btn-success:hover{background:var(--success-600)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:.8125rem}.btn-icon{width:36px;height:36px;padding:0}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 10px;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);white-space:nowrap}.chip-dot{width:6px;height:6px;border-radius:50%}.chip-running{background:var(--info-50);color:var(--info-500)}.chip-running .chip-dot{background:var(--info-500)}.chip-success{background:var(--success-50);color:var(--success-500)}.chip-success .chip-dot{background:var(--success-500)}.chip-failed{background:var(--error-50);color:var(--error-500)}.chip-failed .chip-dot{background:var(--error-500)}.chip-pending{background:var(--warning-50);color:var(--warning-500)}.chip-pending .chip-dot{background:var(--warning-500)}.chip-neutral{background:var(--grey-200);color:var(--grey-700)}.chip-neutral .chip-dot{background:var(--grey-500)}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:.875rem;font-weight:600;margin-bottom:var(--space-1);color:var(--on-surface)}.form-hint{font-size:.75rem;color:var(--on-surface-secondary);margin-top:var(--space-1)}.input,.select,.textarea{width:100%;padding:var(--space-2) var(--space-3);font-family:var(--font-family);font-size:.875rem;color:var(--on-surface);background:var(--surface);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #1976d21f}.textarea{min-height:80px;resize:vertical}.checkbox-group{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:.875rem}.checkbox-group input{accent-color:var(--primary-500);width:16px;height:16px;cursor:pointer}.switch{position:relative;width:40px;height:22px;display:inline-block}.switch input{opacity:0;width:0;height:0}.switch-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--grey-400);border-radius:var(--radius-full);transition:var(--transition-fast);cursor:pointer}.switch-slider:before{content:"";position:absolute;width:16px;height:16px;left:3px;top:3px;background:#fff;border-radius:50%;transition:var(--transition-fast)}.switch input:checked+.switch-slider{background:var(--primary-500)}.switch input:checked+.switch-slider:before{transform:translate(18px)}.table-container{overflow-x:auto;border:1px solid var(--divider);border-radius:var(--radius-lg);background:var(--surface)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead{background:var(--surface-variant)}th{text-align:left;padding:var(--space-3) var(--space-4);font-weight:600;color:var(--on-surface-secondary);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--divider);white-space:nowrap}td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--divider);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--grey-50)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);font-size:.875rem;border:1px solid}.alert i{font-size:20px;margin-top:1px}.alert-info{background:var(--info-50);border-color:#b3e5fc;color:#01579b}.alert-success{background:var(--success-50);border-color:#c8e6c9;color:var(--success-600)}.alert-warning{background:var(--warning-50);border-color:#ffe0b2;color:#bf360c}.alert-error{background:var(--error-50);border-color:#ffcdd2;color:var(--error-600)}.avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-100);color:var(--primary-700);display:flex;align-items:center;justify-content:center;font-size:.8125rem;font-weight:700}.avatar-sm{width:24px;height:24px;font-size:.625rem}.avatar-lg{width:40px;height:40px;font-size:1rem}.breadcrumbs{display:flex;align-items:center;gap:var(--space-2);font-size:.8125rem;color:var(--on-surface-secondary);margin-bottom:var(--space-4)}.breadcrumbs a{color:var(--on-surface-secondary)}.breadcrumbs .current{color:var(--on-surface);font-weight:600}.progress-bar{height:6px;background:var(--grey-200);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-normal);background:var(--primary-500)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6)}.empty-state i{font-size:48px;color:var(--grey-400);margin-bottom:var(--space-4);display:block}.empty-state h3{margin-bottom:var(--space-2)}.empty-state p{color:var(--on-surface-secondary);margin-bottom:var(--space-5)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:999}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--elevation-4);width:90%;max-width:520px;max-height:85vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--divider)}.modal-body{padding:var(--space-5)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--divider)}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);position:absolute;bottom:100%;left:50%;transform:translate(-50%) translateY(-4px);padding:4px 8px;background:var(--grey-900);color:#fff;font-size:.75rem;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--transition-fast);z-index:10}[data-tooltip]:hover:after{opacity:1}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.w-full{width:100%}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.pulse{animation:pulse 2s ease-in-out infinite}.auth-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--background)}.auth-card{width:100%;max-width:420px;background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-xl);box-shadow:var(--elevation-3);padding:var(--space-8)}.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-6)}.auth-logo img{height:40px}.sidebar{width:var(--sidebar-width);background:#1d2125;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:visible;transition:width var(--transition-normal)}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-header{height:72px;display:flex;align-items:center;justify-content:center;padding:var(--space-3);border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0;overflow:hidden}.sidebar-logo{height:44px;max-width:100%;transition:height var(--transition-normal)}.sidebar.collapsed .sidebar-logo{height:36px}.sidebar-toggle{position:absolute;top:56px;right:-12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--surface);color:var(--on-surface-secondary);border:1px solid var(--divider);border-radius:50%;cursor:pointer;box-shadow:var(--elevation-2);z-index:110;padding:0;transition:color var(--transition-fast),background var(--transition-fast)}.sidebar-toggle:hover{color:var(--primary-500);background:var(--grey-50)}.sidebar-toggle i{font-size:16px;line-height:1}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-2);display:flex;flex-direction:column}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:#ffffff8c;font-size:.875rem;font-weight:500;cursor:pointer;text-decoration:none;margin-bottom:2px;white-space:nowrap;background:none;border:none;width:100%;text-align:left;font-family:var(--font-family);overflow:hidden}.nav-item:hover{background:#ffffff0f;color:#ffffffe6;text-decoration:none}.nav-item.active{background:#ffffff14;color:#4d9bf0;font-weight:600}.nav-item i{font-size:20px;width:20px;text-align:center;flex-shrink:0}.nav-label{flex:1;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--transition-fast)}.sidebar.collapsed .nav-item{justify-content:center;padding:var(--space-2)}.sidebar.collapsed .nav-label{display:none}.nav-badge{margin-left:auto;background:var(--error-500);color:#fff;font-size:.625rem;font-weight:700;padding:1px 6px;border-radius:var(--radius-full);min-width:18px;text-align:center}.sidebar.collapsed .nav-badge{margin-left:0;position:absolute;top:2px;right:4px;padding:0 4px;min-width:16px;font-size:.5625rem}.sidebar.collapsed .nav-item{position:relative}.sidebar-footer{border-top:1px solid rgba(255,255,255,.08);padding:var(--space-3);position:relative}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);overflow:hidden}.sidebar-user:hover{background:#ffffff0f}.sidebar-user .avatar{background:#ffffff1f;color:#ffffffb3;flex-shrink:0}.sidebar-user-info{min-width:0;overflow:hidden}.sidebar-user-name{font-size:.8125rem;font-weight:600;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{font-size:.6875rem;color:#fff6}.sidebar.collapsed .sidebar-user{justify-content:center}.sidebar.collapsed .sidebar-user-info{display:none}.user-dropdown{position:absolute;bottom:100%;left:var(--space-2);right:var(--space-2);margin-bottom:var(--space-2);background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-md);box-shadow:var(--elevation-4);padding:var(--space-1) 0;z-index:200;min-width:200px}.sidebar.collapsed .user-dropdown{left:var(--space-2);right:auto;width:220px}.user-dropdown-header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--divider)}.user-dropdown-name{font-size:.875rem;font-weight:600;color:var(--on-surface)}.user-dropdown-role{font-size:.75rem;color:var(--on-surface-secondary)}.user-dropdown-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:.875rem;color:var(--on-surface);cursor:pointer}.user-dropdown-item:hover{background:var(--grey-100)}.user-dropdown-item.danger{color:var(--error-500)}.user-dropdown-divider{height:1px;background:var(--divider);margin:var(--space-1) 0}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}body.sidebar-collapsed .main-content{margin-left:var(--sidebar-collapsed-width)}.status-bar{height:var(--status-bar-height);background:var(--surface);border-top:1px solid var(--divider);display:flex;align-items:center;padding:0 var(--space-5);gap:var(--space-4);position:fixed;bottom:0;left:var(--sidebar-width);right:0;z-index:50;transition:left var(--transition-normal)}body.sidebar-collapsed .status-bar{left:var(--sidebar-collapsed-width)}.dispatcher-dot{width:8px;height:8px;border-radius:50%}.dispatcher-dot.online{background:var(--success-500)}.dispatcher-dot.offline{background:var(--error-500);animation:pulse 2s ease-in-out infinite}.project-list{display:flex;flex-direction:column}.project-list-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-3) var(--space-4);border:1px solid var(--divider);border-radius:var(--radius-lg);margin-bottom:var(--space-2);background:var(--surface)}.project-list-item:hover{background:var(--grey-50);border-color:var(--grey-300)}.project-list-info{flex:1;min-width:0;cursor:pointer}.project-list-info h4{margin-bottom:2px;font-size:.9375rem}.project-list-meta{font-size:.8125rem;color:var(--on-surface-secondary);display:flex;align-items:center;gap:var(--space-2)}.project-list-meta .sep{color:var(--grey-400)}.search-bar{position:relative;max-width:500px;margin-bottom:var(--space-4)}.search-bar i{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--grey-500);font-size:18px}.search-bar input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) 40px;border:1px solid var(--border-color);border-radius:var(--radius-lg);background:var(--surface);font-family:var(--font-family);font-size:.875rem}.search-bar input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #1976d21f}.template-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-4)}.template-card{cursor:pointer}.template-card:hover{box-shadow:var(--elevation-3)}.action-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--surface);color:var(--grey-700);cursor:pointer;text-decoration:none;font-size:16px}.action-btn:hover{background:var(--grey-100);color:var(--on-surface);border-color:var(--grey-400)}.action-btn.danger{color:var(--error-500);border-color:#ffcdd2;background:var(--error-50)}.action-btn.danger:hover{background:var(--error-500);color:#fff}.action-btn:disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.page-header-actions{display:flex;align-items:center;gap:var(--space-2)}.page-header-actions .action-btn{width:32px;height:32px;font-size:18px}.hash-chip{font-family:var(--font-mono);font-size:.6875rem;color:var(--on-surface-secondary);background:var(--surface-variant);border:1px solid var(--divider);padding:2px 8px;border-radius:var(--radius-sm)}.country-chip{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--primary-700);background:var(--primary-50);border:1px solid var(--primary-100);padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap}.country-chip i{font-size:12px}.country-chip-empty{color:var(--on-surface-secondary);background:var(--surface-variant);border:1px dashed var(--divider)}.notify-chip{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;color:var(--info-500);background:var(--info-50);border:1px solid #b3e5fc;padding:2px 8px;border-radius:var(--radius-sm);white-space:nowrap}.notify-chip i{font-size:12px}.result-frame{width:100%;border:1px solid var(--divider);border-radius:var(--radius-lg);background:#fff;display:block}.run-row.unacknowledged td:first-child{border-left:3px solid var(--warning-500)}.run-row.has-changes-ack td:first-child{border-left:3px solid var(--grey-400)}.run-row.no-changes td:first-child{border-left:3px solid var(--success-500)}.run-row.error td:first-child{border-left:3px solid var(--error-500)}.summary-icon{font-size:18px;line-height:1;margin-top:2px}.summary-icon.changes{color:var(--warning-500)}.summary-icon.ack{color:var(--grey-500)}.summary-icon.no-changes{color:var(--success-500)}.summary-icon.error{color:var(--error-500)}.summary-cell{max-width:640px}.summary-cell-inner{display:flex;align-items:flex-start;gap:var(--space-2)}.summary-text{white-space:normal;overflow-wrap:anywhere;word-break:break-word;line-height:1.5;color:var(--on-surface);font-size:.875rem}.browser-row-meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap;margin-top:4px}.browser-row-actions{display:flex;gap:var(--space-1);align-items:center}.email-warning{font-size:.75rem;padding:var(--space-2) var(--space-3);margin-top:var(--space-2)}.profile-section{max-width:480px}.analysis-toolbar{display:flex;gap:var(--space-3);align-items:center;margin-bottom:var(--space-4);flex-wrap:wrap}.filter-chips{display:flex;gap:var(--space-1);flex-wrap:wrap}.filter-chip{padding:4px 12px;font-size:.75rem;font-weight:600;border-radius:var(--radius-full);background:var(--surface);color:var(--on-surface-secondary);border:1px solid var(--divider);cursor:pointer;font-family:var(--font-family);transition:all var(--transition-fast)}.filter-chip:hover{background:var(--grey-100);color:var(--on-surface)}.filter-chip.active{background:var(--primary-500);color:#fff;border-color:var(--primary-500)}.post-list{display:flex;flex-direction:column;gap:var(--space-3)}.post-card{background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-lg);padding:var(--space-4);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.post-card:hover{border-color:var(--grey-300);box-shadow:var(--elevation-1)}.post-card.post-highlight{border-color:var(--primary-500);box-shadow:0 0 0 3px #1976d22e;transition:border-color .3s,box-shadow .3s}.post-card-head{display:flex;align-items:center;gap:var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid var(--divider);margin-bottom:var(--space-3)}.post-card-meta{flex:1;display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.post-card-body .post-text{font-size:.9375rem;line-height:1.55;white-space:pre-wrap;margin-bottom:var(--space-2)}.post-card-footer{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap;margin-top:var(--space-2)}.post-card-footer a{display:inline-flex;align-items:center;gap:4px}.post-card-grade{display:flex;gap:var(--space-3);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--divider)}.grade-chip{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-weight:700;font-size:.8125rem;min-width:40px;padding:2px 8px;border-radius:var(--radius-sm);border:1px solid;letter-spacing:.5px}.grade-chip.grade-unset{background:var(--grey-100);color:var(--grey-500);border-color:var(--grey-300)}.grade-chip.grade-strong{background:var(--success-50);color:var(--success-500);border-color:#c8e6c9}.grade-chip.grade-medium{background:var(--info-50);color:var(--info-500);border-color:#b3e5fc}.grade-chip.grade-weak{background:var(--warning-50);color:var(--warning-500);border-color:#ffe0b2}.grade-chip.grade-poor{background:var(--error-50);color:var(--error-500);border-color:#ffcdd2}.modal.modal-xl{max-width:min(1100px,96vw);width:96vw;max-height:92vh;display:flex;flex-direction:column}.modal.modal-xl .modal-body{flex:1;overflow:auto;min-height:0}.analysis-map{width:100%;height:70vh;min-height:400px;background:var(--grey-100)}.editor-toolbar{display:flex;gap:2px;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--divider);background:var(--surface-variant);flex-wrap:wrap;align-items:center}.tb-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:30px;height:30px;padding:0 8px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--on-surface);font-family:var(--font-family);font-size:.8125rem;font-weight:600;cursor:pointer}.tb-btn:hover{background:var(--grey-100);border-color:var(--divider)}.tb-btn:disabled{opacity:.4;cursor:not-allowed}.tb-btn i{font-size:16px}.tb-btn-action{padding:0 10px;background:var(--primary-50);color:var(--primary-700)}.tb-btn-action:hover:not(:disabled){background:var(--primary-100)}.tb-sep{width:1px;height:20px;background:var(--divider);margin:0 4px}.report-editor{min-height:50vh;padding:var(--space-5) var(--space-6);outline:none;font-size:.9375rem;line-height:1.6;color:var(--on-surface)}.report-editor:empty:before{content:attr(data-placeholder);color:var(--grey-500);pointer-events:none}.report-editor h1{font-size:1.75rem;margin:.8em 0 .4em}.report-editor h2{font-size:1.4rem;margin:.8em 0 .4em}.report-editor h3{font-size:1.15rem;margin:.8em 0 .4em}.report-editor p{margin:.5em 0}.report-editor ul,.report-editor ol{margin:.5em 0 .5em 1.5em}.report-editor blockquote{border-left:3px solid var(--primary-500);margin:1em 0;padding:.5em 1em;background:var(--surface-variant);border-radius:0 var(--radius-sm) var(--radius-sm) 0}.report-editor code{background:var(--grey-100);padding:1px 5px;border-radius:3px;font-family:var(--font-mono);font-size:.85em}.alert.alert-info i{color:var(--info-500)}.result-iframe{display:block;width:100%;height:80vh;min-height:480px;border:none;background:#fff}.analysis-tag-bar{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap;margin-bottom:var(--space-4);padding:var(--space-2) var(--space-3);background:var(--surface-variant);border:1px solid var(--divider);border-radius:var(--radius-md);font-size:.8125rem}.tag-bar-label{font-size:.6875rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;color:var(--on-surface-secondary);margin-right:var(--space-1)}.post-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:var(--space-3);padding-top:var(--space-2);border-top:1px dashed var(--divider);align-items:center}.tag-chip{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;padding:2px 8px;border-radius:var(--radius-full);border:1px solid;white-space:nowrap;letter-spacing:.2px}.tag-chip.tag-submission{background:var(--surface-variant);color:var(--on-surface-secondary);border-color:var(--divider)}.tag-chip.tag-analyst{background:var(--primary-50);color:var(--primary-600);border-color:var(--primary-500)}.tag-chip.tag-filter-active{background:var(--warning-50);color:var(--warning-600);border-color:var(--warning-500);font-weight:600}.tag-x{background:transparent;border:none;color:inherit;cursor:pointer;padding:0 0 0 2px;font-size:14px;line-height:1;opacity:.75}.tag-x:hover{opacity:1}.tag-input{flex:0 0 auto;min-width:90px;border:none;background:transparent;font-family:var(--font-family);font-size:.75rem;color:var(--on-surface);outline:none;padding:2px 4px}.tag-input::placeholder{color:var(--grey-500);font-style:italic}.tag-picker-wrap{position:relative}.tag-picker{position:absolute;top:100%;left:0;margin-top:4px;background:var(--surface);border:1px solid var(--divider);border-radius:var(--radius-md);box-shadow:var(--elevation-3);min-width:200px;max-height:320px;overflow-y:auto;z-index:100;padding:4px}.tag-picker-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:6px 10px;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-family);font-size:.8125rem;color:var(--on-surface);text-align:left}.tag-picker-item:hover{background:var(--primary-50);color:var(--primary-600)}.tag-picker-count{font-size:.6875rem;color:var(--on-surface-secondary);background:var(--surface-variant);padding:1px 6px;border-radius:var(--radius-sm)}.tag-mode-toggle{display:inline-flex;gap:2px;border:1px solid var(--divider);border-radius:var(--radius-md);overflow:hidden;background:var(--surface)}.tag-mode-toggle .filter-chip{border:none;border-radius:0;font-size:.6875rem;padding:2px 8px}.post-card-main{display:flex;gap:var(--space-3);align-items:flex-start}.post-thumb{flex-shrink:0;width:80px;height:80px;border-radius:var(--radius-md);overflow:hidden;background:var(--grey-100);border:1px solid var(--divider)}.post-thumb img{width:100%;height:100%;object-fit:cover;display:block}.post-text{flex:1;margin:0;font-size:.9375rem;line-height:1.55;white-space:pre-wrap}.link-btn{background:transparent;border:none;color:var(--primary-500);font-family:var(--font-family);font-size:.75rem;cursor:pointer;padding:2px 6px;border-radius:var(--radius-sm);display:inline-flex;align-items:center;gap:4px}.link-btn:hover{background:var(--primary-50);color:var(--primary-600)}
