:root{--color-primary-50:#f6f8fa;--color-primary-100:#eaf1f5;--color-primary-200:#d4e4ed;--color-primary-300:#94b4c1;--color-primary-400:#547792;--color-primary-500:#3b82c4;--color-primary-600:#2d4f6e;--color-primary-700:#1e3650;--color-primary-800:#172e48;--color-primary-900:#0f2236;--color-complementary-500:#f5a623;--color-complementary-400:#f7b84d;--color-complementary-300:#f9ca77;--color-gray-50:#f8f9fb;--color-gray-100:#f0f3f7;--color-gray-200:#e4e8ed;--color-gray-300:#d0d6dd;--color-gray-400:#a0abb5;--color-gray-500:#707d89;--color-gray-600:#515d69;--color-gray-700:#3b4752;--color-gray-800:#28333d;--color-gray-900:#1a2430;--color-success:#2e8b57;--color-success-light:#e6f3ec;--color-success-dark:#247048;--color-warning:#d4943a;--color-warning-light:#f7edda;--color-warning-dark:#b87d2e;--color-in-progress:#f5a623;--color-in-progress-light:#fef4e0;--color-in-progress-dark:#d08e1d;--color-danger:#c0392b;--color-danger-light:#f5e2e0;--color-danger-dark:#a13025;--color-info:#3b82c4;--color-info-light:#eaf1f5;--color-info-dark:#1e3650;--color-background:#fff;--color-surface:#f6f8fa;--color-surface-hover:#eaf1f5;--color-border:#d4e4ed;--color-border-light:#eaf1f5;--color-border-dark:#b8cdd9;--color-code-bg:#172e48;--color-code-text:#d4e4ed;--color-code-muted:#94b4c1;--color-code-dim:#547792;--color-code-info:#3b82c4;--color-code-warn:#f5a623;--color-code-error:#f87171;--color-code-error-text:#fca5a5;--color-text-primary:#1e3650;--color-text-secondary:#547792;--color-text-tertiary:#94b4c1;--color-text-inverse:#fff;--spacing-0:0;--spacing-1:.25rem;--spacing-2:.5rem;--spacing-3:.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--spacing-24:6rem;--font-family-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-family-mono:"IBM Plex Mono", "Courier New", monospace;--font-size-2xs:.625rem;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-size-5xl:3rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-none:1;--line-height-tight:1.25;--line-height-snug:1.4;--line-height-normal:1.5;--line-height-relaxed:1.75;--letter-spacing-tight:-.025em;--letter-spacing-normal:0;--letter-spacing-wide:.025em;--letter-spacing-wider:.05em;--border-radius-none:0;--border-radius-sm:.25rem;--border-radius-md:.5rem;--border-radius-lg:.75rem;--border-radius-xl:1rem;--border-radius-full:9999px;--border-width:1px;--border-width-2:2px;--border-width-4:4px;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000040;--shadow-focus:0 0 0 3px #3b82c426;--shadow-inner:inset 0 2px 4px 0 #0000000f;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.2s cubic-bezier(.4, 0, .2, 1);--transition-slow:.3s cubic-bezier(.4, 0, .2, 1);--transition-slower:.5s cubic-bezier(.4, 0, .2, 1);--z-index-dropdown:1000;--z-index-sticky:1020;--z-index-fixed:1030;--z-index-modal-backdrop:1040;--z-index-modal:1050;--z-index-popover:1060;--z-index-tooltip:1070;--z-index-toast:1080;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px;--container-sm:640px;--container-md:768px;--container-lg:1024px;--container-xl:1280px}*,:before,:after{box-sizing:border-box}*{margin:0;padding:0}ul,ol{list-style:none}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;max-width:100vw;height:100%;overflow-x:hidden}html:focus-within{scroll-behavior:smooth}body{min-height:100%;line-height:var(--line-height-normal);text-rendering:optimizespeed;font-family:var(--font-family-sans);color:var(--color-text-primary);background-color:var(--color-background);width:100%;overflow-x:hidden}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}:focus:not(:focus-visible){outline:none}h1,h2,h3,h4,h5,h6{overflow-wrap:break-word;line-height:var(--line-height-tight);font-weight:var(--font-weight-semibold)}p{overflow-wrap:break-word}table{border-collapse:collapse;width:100%}#root{isolation:isolate;width:100%;max-width:100vw;min-height:100vh;overflow-x:hidden}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}.gap-8{gap:var(--spacing-8)}.m-0{margin:var(--spacing-0)}.m-1{margin:var(--spacing-1)}.m-2{margin:var(--spacing-2)}.m-3{margin:var(--spacing-3)}.m-4{margin:var(--spacing-4)}.m-6{margin:var(--spacing-6)}.m-8{margin:var(--spacing-8)}.mt-0{margin-top:var(--spacing-0)}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-3{margin-top:var(--spacing-3)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-0{margin-bottom:var(--spacing-0)}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.ml-0{margin-left:var(--spacing-0)}.ml-1{margin-left:var(--spacing-1)}.ml-2{margin-left:var(--spacing-2)}.ml-3{margin-left:var(--spacing-3)}.ml-4{margin-left:var(--spacing-4)}.ml-auto{margin-left:auto}.mr-0{margin-right:var(--spacing-0)}.mr-1{margin-right:var(--spacing-1)}.mr-2{margin-right:var(--spacing-2)}.mr-3{margin-right:var(--spacing-3)}.mr-4{margin-right:var(--spacing-4)}.mr-auto{margin-right:auto}.p-0{padding:var(--spacing-0)}.p-1{padding:var(--spacing-1)}.p-2{padding:var(--spacing-2)}.p-3{padding:var(--spacing-3)}.p-4{padding:var(--spacing-4)}.p-6{padding:var(--spacing-6)}.p-8{padding:var(--spacing-8)}.pt-0{padding-top:var(--spacing-0)}.pt-1{padding-top:var(--spacing-1)}.pt-2{padding-top:var(--spacing-2)}.pt-3{padding-top:var(--spacing-3)}.pt-4{padding-top:var(--spacing-4)}.pt-6{padding-top:var(--spacing-6)}.pt-8{padding-top:var(--spacing-8)}.pb-0{padding-bottom:var(--spacing-0)}.pb-1{padding-bottom:var(--spacing-1)}.pb-2{padding-bottom:var(--spacing-2)}.pb-3{padding-bottom:var(--spacing-3)}.pb-4{padding-bottom:var(--spacing-4)}.pb-6{padding-bottom:var(--spacing-6)}.pb-8{padding-bottom:var(--spacing-8)}.px-0{padding-left:var(--spacing-0);padding-right:var(--spacing-0)}.px-1{padding-left:var(--spacing-1);padding-right:var(--spacing-1)}.px-2{padding-left:var(--spacing-2);padding-right:var(--spacing-2)}.px-3{padding-left:var(--spacing-3);padding-right:var(--spacing-3)}.px-4{padding-left:var(--spacing-4);padding-right:var(--spacing-4)}.px-6{padding-left:var(--spacing-6);padding-right:var(--spacing-6)}.px-8{padding-left:var(--spacing-8);padding-right:var(--spacing-8)}.py-0{padding-top:var(--spacing-0);padding-bottom:var(--spacing-0)}.py-1{padding-top:var(--spacing-1);padding-bottom:var(--spacing-1)}.py-2{padding-top:var(--spacing-2);padding-bottom:var(--spacing-2)}.py-3{padding-top:var(--spacing-3);padding-bottom:var(--spacing-3)}.py-4{padding-top:var(--spacing-4);padding-bottom:var(--spacing-4)}.py-6{padding-top:var(--spacing-6);padding-bottom:var(--spacing-6)}.py-8{padding-top:var(--spacing-8);padding-bottom:var(--spacing-8)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-3xl{font-size:var(--font-size-3xl)}.text-4xl{font-size:var(--font-size-4xl)}.font-normal{font-weight:var(--font-weight-normal)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-inverse{color:var(--color-text-inverse)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.text-info{color:var(--color-info)}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.max-w-xs{max-width:320px}.max-w-sm{max-width:384px}.max-w-md{max-width:448px}.max-w-lg{max-width:512px}.max-w-xl{max-width:576px}.max-w-2xl{max-width:672px}.max-w-3xl{max-width:768px}.max-w-4xl{max-width:896px}.max-w-5xl{max-width:1024px}.max-w-6xl{max-width:1152px}.max-w-7xl{max-width:1280px}.max-w-full{max-width:100%}.rounded-none{border-radius:var(--border-radius-none)}.rounded-sm{border-radius:var(--border-radius-sm)}.rounded-md{border-radius:var(--border-radius-md)}.rounded-lg{border-radius:var(--border-radius-lg)}.rounded-xl{border-radius:var(--border-radius-xl)}.rounded-full{border-radius:var(--border-radius-full)}.border{border:var(--border-width) solid var(--color-border)}.border-t{border-top:var(--border-width) solid var(--color-border)}.border-b{border-bottom:var(--border-width) solid var(--color-border)}.border-l{border-left:var(--border-width) solid var(--color-border)}.border-r{border-right:var(--border-width) solid var(--color-border)}.shadow-none{box-shadow:none}.shadow-xs{box-shadow:var(--shadow-xs)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.container{width:100%;padding-left:var(--spacing-4);padding-right:var(--spacing-4);margin-left:auto;margin-right:auto}@media (width>=640px){.container{max-width:var(--container-sm)}}@media (width>=768px){.container{max-width:var(--container-md)}}@media (width>=1024px){.container{max-width:var(--container-lg)}}@media (width>=1280px){.container{max-width:var(--container-xl)}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}code{font-family:var(--font-family-mono);background-color:var(--color-gray-100);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm);font-size:.9em}pre code{background-color:#0000;padding:0}.toast-container{z-index:var(--z-index-toast);gap:var(--spacing-3);padding:var(--spacing-4);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast-position-top-right{top:0;right:0}.toast-position-top-center{top:0;left:50%;transform:translate(-50%)}.toast-position-bottom-right{bottom:0;right:0}.toast-position-bottom-center{bottom:0;left:50%;transform:translate(-50%)}.toast{align-items:center;gap:var(--spacing-3);min-width:300px;max-width:500px;padding:var(--spacing-4);background-color:var(--color-background);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideIn var(--transition-base);display:flex}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-message{font-size:var(--font-size-sm);color:var(--color-text-primary);flex:1}.toast-close{padding:var(--spacing-1);border-radius:var(--border-radius-sm);color:var(--color-text-secondary);transition:all var(--transition-base);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.toast-close:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.toast-success{border-left:4px solid var(--color-success)}.toast-success .toast-icon{color:var(--color-success)}.toast-error{border-left:4px solid var(--color-danger)}.toast-error .toast-icon{color:var(--color-danger)}.toast-warning{border-left:4px solid var(--color-warning)}.toast-warning .toast-icon{color:var(--color-warning)}.toast-info{border-left:4px solid var(--color-info)}.toast-info .toast-icon{color:var(--color-info)}@media (width<=640px){.toast-container{padding:var(--spacing-2)}.toast{min-width:unset;max-width:calc(100vw - var(--spacing-4))}}.navbar{background-color:var(--color-background);border-bottom:var(--border-width) solid var(--color-border);z-index:var(--z-index-sticky);width:100%;max-width:100vw;position:sticky;top:0;overflow-x:hidden}.navbar-container{padding:0 var(--spacing-6);justify-content:space-between;align-items:center;width:100%;height:64px;margin:0;display:flex}.navbar-brand a{align-items:center;gap:var(--spacing-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);transition:color var(--transition-base);letter-spacing:var(--letter-spacing-tight);text-decoration:none;display:flex}.navbar-brand a:hover{color:var(--color-text-primary)}.navbar-brand img{width:auto;height:28px}.navbar-mobile-toggle{padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-primary);cursor:pointer;transition:background-color var(--transition-base);background:0 0;border:none;display:none}.navbar-mobile-toggle:hover{background-color:var(--color-surface-hover)}.navbar-menu{align-items:center;gap:var(--spacing-8);margin-left:var(--spacing-8);flex:1;justify-content:space-between;display:flex}.navbar-links{align-items:center;gap:var(--spacing-2);display:flex}.navbar-link{align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-base);text-decoration:none;display:flex;position:relative}.navbar-link:hover{color:var(--color-primary-600);background-color:var(--color-surface-hover)}.navbar-link-active{color:var(--color-primary-600);background-color:var(--color-primary-50)}.navbar-link-active:after{content:"";background-color:var(--color-primary-600);height:2px;position:absolute;bottom:-1px;left:0;right:0}.navbar-user-section{align-items:center;gap:var(--spacing-3);display:flex;position:relative}.navbar-user{align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background-color:var(--color-surface);border-radius:var(--border-radius-md);display:flex}.navbar-user--clickable{cursor:pointer;transition:background-color var(--transition-base)}.navbar-user--clickable:hover,.navbar-user--open{background-color:var(--color-surface-hover)}.navbar-user-avatar{border-radius:var(--border-radius-full);background-color:var(--color-primary-100);width:32px;height:32px;color:var(--color-primary-600);flex-shrink:0;justify-content:center;align-items:center;display:flex}.navbar-user-avatar-img{object-fit:cover;border-radius:50%;width:24px;height:24px;display:block}.navbar-user-info{line-height:var(--line-height-tight);flex-direction:column;display:flex}.navbar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.navbar-user-workspace{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.navbar-user-chevron{color:var(--color-text-tertiary);flex-shrink:0;transition:transform .2s}.navbar-user-chevron--open{transform:rotate(180deg)}.navbar-logout{padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.navbar-logout:hover{color:var(--color-danger);background-color:var(--color-danger-light)}.navbar-credits-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-warning-dark);background-color:var(--color-warning-light);border:1px solid var(--color-warning);cursor:pointer;transition:opacity var(--transition-base);border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;text-decoration:none;display:flex}.navbar-credits-badge:hover{opacity:.85}.navbar-credits-badge--exhausted{color:var(--color-danger-dark);background-color:var(--color-danger-light);border-color:var(--color-danger)}span.navbar-credits-badge{cursor:default}.navbar-offline-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-warning-dark);background-color:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:9999px;align-items:center;gap:4px;padding:2px 8px;display:flex}.tenant-dropdown-backdrop{z-index:998;position:fixed;inset:0}.tenant-dropdown-menu{background:var(--color-background);border-radius:var(--border-radius-lg);min-width:240px;box-shadow:var(--shadow-lg);border:var(--border-width) solid var(--color-border);z-index:999;position:fixed;overflow:hidden}.tenant-dropdown-header{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);border-bottom:var(--border-width) solid var(--color-border)}.tenant-dropdown-item{padding:var(--spacing-3) var(--spacing-4);cursor:pointer;background:var(--color-background);transition:background var(--transition-base);border-left:3px solid #0000}.tenant-dropdown-item:hover{background:var(--color-surface-hover)}.tenant-dropdown-item--active{background:var(--color-surface);border-left-color:var(--color-primary-500)}.tenant-dropdown-item--active:hover{background:var(--color-surface)}.tenant-dropdown-item-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px}.tenant-dropdown-item-meta{gap:var(--spacing-2);align-items:center;display:flex}.tenant-dropdown-role{font-size:var(--font-size-xs);padding:1px var(--spacing-2);border-radius:var(--border-radius-sm);text-transform:capitalize}.tenant-dropdown-role--owner{background-color:var(--color-success-light);color:var(--color-success-dark)}.tenant-dropdown-role--member{background-color:var(--color-surface);color:var(--color-text-secondary)}.tenant-dropdown-default{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.tenant-dropdown-divider{background-color:var(--color-border);height:1px;margin:var(--spacing-1) 0}.tenant-dropdown-item--invited{border-left:3px solid var(--color-warning)}.tenant-dropdown-item--loading{opacity:.6;pointer-events:none}.tenant-dropdown-role--invited{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.tenant-dropdown-inviter,.tenant-dropdown-joining{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}@media (width<=768px){.navbar-container{padding:0 var(--spacing-4);height:56px}.navbar-mobile-toggle{display:flex}.navbar-menu{background-color:var(--color-background);padding:var(--spacing-4);transition:transform var(--transition-base);flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;margin-left:0;position:fixed;inset:56px 0 0;overflow-y:auto;transform:translate(100%)}.navbar-menu-open{box-shadow:var(--shadow-lg);transform:translate(0)}.navbar-links{align-items:stretch;gap:var(--spacing-2);padding-bottom:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border);margin-bottom:var(--spacing-6);flex-direction:column}.navbar-link{padding:var(--spacing-3) var(--spacing-4);justify-content:flex-start}.navbar-link-active:after{display:none}.navbar-user-section{align-items:stretch;gap:var(--spacing-3);flex-direction:column}.navbar-user,.navbar-logout{justify-content:flex-start}}.btn{justify-content:center;align-items:center;gap:var(--spacing-2);font-weight:var(--font-weight-medium);border-radius:var(--border-radius-md);transition:all var(--transition-base);cursor:pointer;border:var(--border-width) solid transparent;white-space:nowrap;outline:none;display:inline-flex}.btn:focus-visible{box-shadow:var(--shadow-focus)}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-sm{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);min-height:32px}.btn-md{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);min-height:40px}.btn-lg{padding:var(--spacing-4) var(--spacing-6);font-size:var(--font-size-lg);min-height:48px}.btn-primary{background-color:var(--color-primary-500);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-700);transform:translateY(0)}.btn-secondary{background-color:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background-color:var(--color-surface-hover);border-color:var(--color-border-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary:active:not(:disabled){background-color:var(--color-gray-200);transform:translateY(0)}.btn-success{background-color:var(--color-success);color:var(--color-text-inverse)}.btn-success:hover:not(:disabled){background-color:var(--color-success-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-success:active:not(:disabled){background-color:var(--color-success-dark);transform:translateY(0)}.btn-danger{background-color:var(--color-danger);color:var(--color-text-inverse)}.btn-danger:hover:not(:disabled){background-color:var(--color-danger-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-danger:active:not(:disabled){background-color:var(--color-danger-dark);transform:translateY(0)}.btn-ghost{color:var(--color-text-primary);background-color:#0000}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-hover)}.btn-ghost:active:not(:disabled){background-color:var(--color-gray-200)}.btn-link{color:var(--color-primary-500);background-color:#0000;height:auto;min-height:auto;padding:0}.btn-link:hover:not(:disabled){color:var(--color-primary-600);text-decoration:underline}.btn-link:active:not(:disabled){color:var(--color-primary-700)}.btn-full-width{width:100%}.btn-icon{justify-content:center;align-items:center;display:inline-flex}.btn-icon-loading{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.btn-content{align-items:center;display:inline-flex}.btn:not(:has(.btn-content)){padding:var(--spacing-2);aspect-ratio:1;min-width:auto}.btn-sm:not(:has(.btn-content)){padding:var(--spacing-2);width:32px;height:32px}.btn-md:not(:has(.btn-content)){padding:var(--spacing-2);width:40px;height:40px}.btn-lg:not(:has(.btn-content)){padding:var(--spacing-3);width:48px;height:48px}.input-container{gap:var(--spacing-2);flex-direction:column;display:flex}.input-full-width{width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.input-wrapper{align-items:center;display:flex;position:relative}.input{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);background-color:var(--color-background);width:100%;color:var(--color-text-primary);transition:all var(--transition-base);outline:none}.input:hover{border-color:var(--color-border-dark)}.input:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.input::placeholder{color:var(--color-text-tertiary)}.input:disabled{background-color:var(--color-surface);cursor:not-allowed;opacity:.6}.input-sm{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);min-height:32px}.input-md{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);min-height:40px}.input-lg{padding:var(--spacing-4) var(--spacing-5);font-size:var(--font-size-lg);min-height:48px}.input-has-left-icon.input-sm{padding-left:var(--spacing-8)}.input-has-left-icon.input-md{padding-left:var(--spacing-10)}.input-has-left-icon.input-lg{padding-left:var(--spacing-12)}.input-has-right-icon.input-sm{padding-right:var(--spacing-8)}.input-has-right-icon.input-md{padding-right:var(--spacing-10)}.input-has-right-icon.input-lg{padding-right:var(--spacing-12)}.input-icon{color:var(--color-text-tertiary);pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute}.input-icon-left{left:var(--spacing-3)}.input-icon-right{right:var(--spacing-3)}.input-error{border-color:var(--color-danger)}.input-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef44441a}.input-error-message{font-size:var(--font-size-sm);color:var(--color-danger)}.input-help-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.login-page{min-height:100vh;display:flex}.login-brand-panel{background:linear-gradient(160deg, var(--color-primary-800) 0%, var(--color-primary-600) 50%, var(--color-primary-500) 100%);color:var(--color-background);padding:var(--spacing-12) var(--spacing-8);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-brand-panel:before{content:"";pointer-events:none;background:radial-gradient(circle at 20% 80%,#ffffff0f 0%,#0000 50%),radial-gradient(circle at 80% 20%,#ffffff0a 0%,#0000 50%);position:absolute;inset:0}.login-brand-content{width:100%;max-width:480px;position:relative}.login-brand-logo{align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-10);display:flex}.login-brand-logo img{width:auto;height:44px}.login-mobile-logo img{width:auto;height:36px}.login-brand-name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-tight)}.login-brand-headline{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight);margin:0 0 var(--spacing-5) 0}.login-brand-description{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);color:#fffc;margin:0 0 var(--spacing-10) 0}.login-brand-features{gap:var(--spacing-5);flex-direction:column;display:flex}.login-brand-feature{align-items:flex-start;gap:var(--spacing-4);display:flex}.login-brand-feature>svg{color:#ffffffb3;flex-shrink:0;margin-top:2px}.login-brand-feature div{flex-direction:column;gap:2px;display:flex}.login-brand-feature strong{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.login-brand-feature span{font-size:var(--font-size-sm);color:#ffffffa6;line-height:var(--line-height-normal)}.login-form-panel{background:var(--color-background);padding:var(--spacing-12) var(--spacing-8);flex:1;justify-content:center;align-items:center;display:flex}.login-form-container{width:100%;max-width:400px}.login-mobile-logo{align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-6);display:none}.login-mobile-brand{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.login-form-header{margin-bottom:var(--spacing-8)}.login-form-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0;line-height:var(--line-height-tight)}.login-form-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.login-form{gap:var(--spacing-5);flex-direction:column;display:flex}.login-error{padding:var(--spacing-3) var(--spacing-4);background-color:var(--color-danger-light);border:var(--border-width) solid var(--color-danger);border-radius:var(--border-radius-md);color:var(--color-danger-dark);font-size:var(--font-size-sm);text-align:center}.login-footer{margin-top:var(--spacing-6);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.login-footer strong{color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.login-divider{margin:var(--spacing-5) 0;color:var(--color-text-tertiary);align-items:center;display:flex}.login-divider-line{border-bottom:1px solid var(--color-border);flex:1}.login-divider-text{padding:0 var(--spacing-3);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.oauth-sign-in-btn{border:1px solid var(--color-border);border-radius:var(--border-radius-md);background:var(--color-background);cursor:pointer;width:100%;font-family:var(--font-family-sans);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:background-color var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);align-items:center;height:44px;padding:0;display:flex;overflow:hidden}.oauth-sign-in-btn:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-dark)}.oauth-sign-in-btn:active{background-color:var(--color-surface)}.oauth-sign-in-btn:focus-visible{outline:2px solid var(--color-primary-500);outline-offset:2px}.google-icon-wrapper{flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.google-sign-in-text{text-align:center;flex:1;padding-right:44px}.login-legal-links{margin-top:var(--spacing-5);text-align:center;font-size:var(--font-size-xs)}.login-legal-links a{color:var(--color-text-tertiary);transition:color var(--transition-fast);text-decoration:none}.login-legal-links a:hover{color:var(--color-text-secondary);text-decoration:underline}.login-legal-separator{margin:0 var(--spacing-2);color:var(--color-text-tertiary)}@media (width<=960px){.login-brand-panel{display:none}.login-form-panel{flex:1}.login-mobile-logo{display:flex}}@media (width<=640px){.login-form-panel{padding:var(--spacing-6) var(--spacing-4)}.login-form-title{font-size:var(--font-size-xl)}}.tenant-selector-page{background:linear-gradient(135deg, var(--color-primary-50) 0%, var(--color-background) 100%);min-height:100vh;padding:var(--spacing-6);justify-content:center;align-items:center;display:flex}.tenant-selector-container{width:100%;max-width:520px}.tenant-selector-header{text-align:center;margin-bottom:var(--spacing-8)}.tenant-selector-logo{border-radius:var(--border-radius-xl);background:linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-600) 100%);width:80px;height:80px;color:var(--color-text-inverse);margin-bottom:var(--spacing-4);box-shadow:var(--shadow-lg);justify-content:center;align-items:center;display:inline-flex}.tenant-selector-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0;line-height:var(--line-height-tight)}.tenant-selector-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0}.tenant-selector-list{gap:var(--spacing-3);flex-direction:column;display:flex}.tenant-selector-card{background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-5) var(--spacing-6);cursor:pointer;box-shadow:var(--shadow-sm);justify-content:space-between;align-items:center;transition:all .2s;display:flex}.tenant-selector-card:hover{border-color:var(--color-primary-300);box-shadow:var(--shadow-md);transform:translateY(-1px)}.tenant-selector-card-info{flex:1}.tenant-selector-card-name{margin:0 0 var(--spacing-2) 0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.tenant-selector-badges{gap:var(--spacing-2);align-items:center;display:flex}.tenant-selector-badge{padding:2px var(--spacing-3);border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize;display:inline-block}.tenant-selector-badge--owner{background-color:var(--color-success-light);color:var(--color-success-dark)}.tenant-selector-badge--member{background-color:var(--color-surface);color:var(--color-text-secondary)}.tenant-selector-badge--default{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.tenant-selector-arrow{font-size:var(--font-size-xl);color:var(--color-text-tertiary);margin-left:var(--spacing-4)}.tenant-selector-section-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);margin-top:var(--spacing-2)}.tenant-selector-card--invited{border-left:3px solid var(--color-warning)}.tenant-selector-card--loading{opacity:.6;pointer-events:none}.tenant-selector-badge--invited{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.tenant-selector-badge--inviter{color:var(--color-text-tertiary);background-color:#0000}.tenant-selector-error{margin-top:var(--spacing-4);text-align:center;font-size:var(--font-size-sm);color:var(--color-danger)}.tenant-selector-footer{margin-top:var(--spacing-6);text-align:center;font-size:var(--font-size-sm);color:var(--color-text-secondary)}@media (width<=640px){.tenant-selector-page{padding:var(--spacing-4)}.tenant-selector-title{font-size:var(--font-size-2xl)}.tenant-selector-logo{width:64px;height:64px}.tenant-selector-logo svg{width:32px;height:32px}.tenant-selector-card{padding:var(--spacing-4) var(--spacing-5)}}.skeleton{background:linear-gradient(90deg, var(--color-gray-200) 0%, var(--color-gray-100) 50%, var(--color-gray-200) 100%);border-radius:var(--border-radius-sm);background-size:200% 100%;animation:1.5s ease-in-out infinite loading}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-text{width:100%;height:1rem;margin-bottom:var(--spacing-2)}.skeleton-circle{border-radius:var(--border-radius-full)}.skeleton-card{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);margin-bottom:var(--spacing-4);overflow:hidden}.skeleton-card-image{background:linear-gradient(90deg, var(--color-gray-200) 0%, var(--color-gray-100) 50%, var(--color-gray-200) 100%);background-size:200% 100%;width:100%;height:200px;animation:1.5s ease-in-out infinite loading}.skeleton-card-content{padding:var(--spacing-6);gap:var(--spacing-3);flex-direction:column;display:flex}.skeleton-table{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-4);gap:var(--spacing-3);flex-direction:column;display:flex}.skeleton-table-row{gap:var(--spacing-4);grid-template-columns:1fr 1fr 1fr;display:grid}.skeleton-table-row .skeleton-text{margin-bottom:0}.icon-picker-grid{gap:var(--spacing-2);grid-template-columns:repeat(auto-fill,minmax(40px,1fr));display:grid}.icon-picker-item{border:2px solid var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;width:40px;height:40px;color:var(--color-text-secondary);transition:all var(--transition-base);background:0 0;justify-content:center;align-items:center;padding:0;display:flex}.icon-picker-item:hover{border-color:var(--color-border-dark);color:var(--color-text-primary);background-color:var(--color-surface-hover)}.icon-picker-item-selected{border-color:var(--color-primary-500);color:var(--color-primary-500);background-color:var(--color-primary-50,#6366f114);box-shadow:0 0 0 1px var(--color-primary-500)}.icon-picker-item-selected:hover{border-color:var(--color-primary-500);color:var(--color-primary-500);background-color:var(--color-primary-50,#6366f11f)}.project-card{background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-xl);padding:var(--spacing-6);cursor:pointer;transition:all var(--transition-base);gap:var(--spacing-4);flex-direction:column;height:100%;display:flex}.project-card:hover{border-color:var(--color-border-dark);transform:translateY(-2px);box-shadow:0 4px 16px #0000000f}.project-card-top{justify-content:space-between;align-items:flex-start;display:flex}.project-card-top-right{align-items:flex-start;gap:var(--spacing-1);display:flex}.project-card-type-badge{border-radius:var(--border-radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:var(--letter-spacing-wide);line-height:var(--line-height-snug);align-items:center;gap:4px;padding:3px 10px;display:inline-flex}.project-card-score-ring{flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.project-card-score-value{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-info{flex-direction:column;flex:1;gap:4px;min-height:0;display:flex}.project-card-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight);line-height:var(--line-height-tight);margin:0}.project-card-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;display:-webkit-box;overflow:hidden}.project-card-progress{flex-direction:column;gap:6px;display:flex}.project-card-progress-header{justify-content:space-between;align-items:center;display:flex}.project-card-progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.project-card-progress-right{align-items:center;gap:6px;display:flex}.project-card-progress-count{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.project-card-score-ring-sm{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;display:flex;position:relative}.project-card-score-value-sm{font-size:8px;font-weight:var(--font-weight-bold);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-progress-bar{background:var(--color-gray-100);border-radius:2px;height:4px;overflow:hidden}.project-card-progress-fill{height:100%;transition:width var(--transition-slow);border-radius:2px}.project-card-progress-secondary{color:var(--color-text-tertiary);font-size:11px}.project-card-gauge{flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;position:relative}.project-card-gauge-value{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-footer{padding-top:var(--spacing-4);border-top:var(--border-width) solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.project-card-footer-right{align-items:center;gap:.375rem;display:flex}.project-card-action-badge{border-radius:var(--border-radius-full);background:var(--color-warning-light);color:var(--color-warning-dark);font-size:11px;font-weight:var(--font-weight-semibold);align-items:center;gap:3px;padding:2px 6px;line-height:1;display:inline-flex}.project-card-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);align-items:center;gap:4px;display:flex}.project-card-phase{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-gray-100);border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium);text-overflow:ellipsis;white-space:nowrap;max-width:180px;padding:2px 8px;overflow:hidden}.project-card-menu{position:relative}.project-card-menu-btn{width:28px;height:28px;color:var(--color-text-tertiary);border-radius:var(--border-radius-md);cursor:pointer;opacity:0;transition:all var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.project-card:hover .project-card-menu-btn{opacity:1}.project-card-menu-btn:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.project-card-dropdown{z-index:50;background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);min-width:160px;margin-top:4px;padding:4px;position:absolute;top:100%;right:0;box-shadow:0 4px 16px #0000001a,0 1px 4px #0000000f}.project-card-dropdown-item{align-items:center;gap:var(--spacing-2);width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary);border-radius:var(--border-radius-md);cursor:pointer;transition:background var(--transition-base);text-align:left;font-family:var(--font-family-sans);background:0 0;border:none;padding:8px 12px;display:flex}.project-card-dropdown-item:hover{background:var(--color-gray-50)}.project-card-dropdown-danger{color:var(--color-danger)}.project-card-dropdown-danger:hover{background:var(--color-danger-light)}.phase-overview-panel{background:var(--color-background);flex-direction:column;height:100%;display:flex;overflow-y:auto}.phase-overview-scroll{flex:1 0 auto;padding:1.5rem;overflow:visible}.phase-overview-header{margin-bottom:1.5rem}.phase-overview-header-top{justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.25rem;display:flex}.phase-overview-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.phase-overview-order{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.phase-overview-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);margin:0}.phase-overview-grid{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;display:grid}@media (width<=700px){.phase-overview-grid{grid-template-columns:1fr}}.phase-overview-card{border:1px solid var(--color-border);background:var(--color-background);border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000000a}.phase-overview-card-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-secondary);margin:0 0 .75rem}.phase-score-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.phase-score-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-none)}.phase-score-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.phase-criteria-list{flex-direction:column;gap:.5rem;display:flex}.phase-criteria-item{align-items:center;gap:.5rem;display:flex}.phase-criteria-name{font-size:var(--font-size-sm);color:var(--color-gray-700);text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;width:160px;min-width:160px;overflow:hidden}.phase-criteria-bar-track{background:var(--color-border);border-radius:4px;flex:1;height:8px;overflow:hidden}.phase-criteria-bar-fill{border-radius:4px;height:100%;transition:width .3s}.phase-criteria-score{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-align:right;min-width:28px}.phase-no-scores{font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.phase-progress-section{margin-bottom:1rem}.phase-progress-header{justify-content:space-between;align-items:baseline;margin-bottom:.375rem;display:flex}.phase-progress-label{font-size:var(--font-size-sm);color:var(--color-gray-700)}.phase-progress-pct{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.phase-progress-bar{background:var(--color-border);border-radius:5px;height:10px;display:flex;overflow:hidden}.phase-progress-segment{flex:none;height:100%;transition:width .3s}.phase-progress-segment:first-child{border-radius:5px 0 0 5px}.phase-progress-segment:last-child{border-radius:0 5px 5px 0}.phase-progress-segment:only-child{border-radius:5px}.phase-progress-fill{background:var(--color-primary-500);border-radius:5px;height:100%;transition:width .3s}.phase-checklist{flex-direction:column;gap:.375rem;margin:0;padding:0;list-style:none;display:flex}.phase-checklist-item{font-size:var(--font-size-sm);color:var(--color-gray-700);align-items:center;gap:.5rem;display:flex}.phase-checklist-icon{font-size:var(--font-size-sm);text-align:center;flex-shrink:0;width:1rem}.phase-checklist-icon.met{color:var(--color-success-dark)}.phase-checklist-icon.unmet{color:var(--color-danger-dark)}.phase-state-distribution{flex-wrap:wrap;gap:.375rem;margin-top:.75rem;display:flex}.phase-state-chip{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:999px;align-items:center;gap:.25rem;padding:2px 8px;display:inline-flex}.phase-state-chip.state-not-started{background:var(--color-gray-100);color:var(--color-text-secondary)}.phase-state-chip.state-in-progress{background:var(--color-in-progress-light);color:var(--color-in-progress-dark)}.phase-state-chip.state-review{background:var(--color-warning-light);color:var(--color-warning-dark)}.phase-state-chip.state-approved{background:var(--color-primary-100);color:var(--color-primary-700)}.phase-state-chip.state-completed{background:var(--color-success-light);color:var(--color-success-dark)}.phase-state-chip.state-final{background:var(--color-primary-100);color:var(--color-primary-800)}.phase-progress-info-wrapper{align-items:center;display:inline-flex;position:relative}.phase-progress-info{width:14px;height:14px;font-size:var(--font-size-2xs);color:var(--color-text-tertiary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;margin-left:.25rem;display:inline-flex}.phase-progress-tooltip{z-index:50;background:var(--color-gray-800);width:280px;color:var(--color-gray-100);font-size:var(--font-size-xs);line-height:var(--line-height-normal);pointer-events:none;border-radius:.375rem;padding:.625rem .75rem;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 4px 12px #00000026}.phase-progress-tooltip ul{margin:.25rem 0;padding-left:1.25rem}.phase-progress-tooltip li{margin:0}.phase-missing-pages{border-top:1px solid var(--color-border);margin-top:.75rem;padding-top:.75rem}.phase-missing-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:.375rem}.phase-missing-list{flex-wrap:wrap;gap:.375rem;display:flex}.phase-missing-btn{font-size:var(--font-size-xs);border:1px solid var(--color-gray-300);background:var(--color-background);color:var(--color-gray-700);cursor:pointer;border-radius:.25rem;align-items:center;gap:.25rem;padding:.25rem .5rem;transition:all .15s;display:inline-flex}.phase-missing-btn:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary)}.phase-blockers{border-top:1px solid var(--color-border);margin-top:.75rem;padding-top:.75rem}.phase-blockers-header{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-danger-dark);align-items:center;gap:.375rem;margin-bottom:.5rem;display:flex}.phase-blockers-list{flex-direction:column;gap:.375rem;display:flex}.phase-blocker-item{background:var(--color-danger-light);border-radius:.25rem;flex-direction:column;gap:.125rem;padding:.375rem .5rem;display:flex}.phase-blocker-page-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-600);cursor:pointer}.phase-blocker-page-name:hover{text-decoration:underline}.phase-blocker-deps{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.phase-blockers-toggle{width:100%;color:var(--color-primary-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:.25rem;padding:.375rem;display:block}.phase-blockers-toggle:hover{color:var(--color-primary-600);background:var(--color-surface);border-radius:.25rem}.phase-overview-section{margin-bottom:1.5rem}.phase-overview-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-secondary);margin:0 0 .75rem}.phase-page-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.phase-page-table th{text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;padding:.5rem .75rem}.phase-page-table th:hover{color:var(--color-gray-700)}.phase-page-table th .sort-indicator{font-size:var(--font-size-2xs);margin-left:.25rem}.phase-page-table td{border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700);padding:.5rem .75rem}.phase-page-table tr:hover td{background:var(--color-surface)}.phase-page-table tr{cursor:pointer}.phase-page-table .page-title-cell{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.phase-page-table .state-cell{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:999px;align-items:center;padding:2px 8px;display:inline-flex}.phase-page-table .state-not-started{background:var(--color-gray-100);color:var(--color-text-secondary)}.phase-page-table .state-in-progress{background:var(--color-in-progress-light);color:var(--color-in-progress-dark)}.phase-page-table .state-review{background:var(--color-warning-light);color:var(--color-warning-dark)}.phase-page-table .state-approved{background:var(--color-primary-100);color:var(--color-primary-700)}.phase-page-table .state-completed{background:var(--color-success-light);color:var(--color-success-dark)}.phase-page-table .state-final{background:var(--color-primary-100);color:var(--color-primary-800)}.phase-page-table th.agent-col-header,.phase-page-table td.agent-mode-cell{text-align:center;cursor:default;width:28px;min-width:28px;padding:.5rem .25rem .5rem .75rem}.phase-page-table .agent-mode-icon{color:var(--color-primary-500)}.phase-page-table th.score-col-header,.phase-page-table td.score-cell{text-align:center}.phase-page-table td.score-cell{font-weight:var(--font-weight-semibold);cursor:default}.phase-page-table td.comment-count-cell{text-align:center}.phase-page-table .comment-count-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);align-items:center;gap:3px;display:inline-flex}.phase-page-table .comment-count-badge.has-comments{color:var(--color-warning-dark)}.phase-page-table td.lock-cell{text-align:center}.phase-page-table td.lock-cell svg{vertical-align:middle;display:inline-block}.phase-page-table .lock-icon-locked{color:var(--color-danger-dark)}.phase-page-table .lock-icon-unlocked{color:var(--color-success-dark)}.phase-page-table .in-state-cell{color:var(--color-text-tertiary);white-space:nowrap}.phase-page-table .in-state-cell.staleness-warning{color:var(--color-warning-dark);font-weight:var(--font-weight-medium)}.phase-page-table .in-state-cell.staleness-danger{color:var(--color-danger-dark);font-weight:var(--font-weight-semibold)}.phase-page-table-empty{text-align:center;color:var(--color-text-tertiary);font-style:italic;font-size:var(--font-size-sm);padding:1.5rem}.phase-insights-list{flex-direction:column;gap:0;display:flex}.phase-insight-item{border-bottom:1px solid var(--color-gray-100);padding:.625rem 0}.phase-insight-item:last-child{border-bottom:none}.phase-insight-header{align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.phase-insight-page-link{color:var(--color-primary-600);cursor:pointer;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.phase-insight-page-link:hover{text-decoration:underline}.phase-insight-criterion{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.phase-insight-score{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);margin-left:auto}.phase-insight-reasoning{font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:var(--line-height-normal);-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.phase-insight-reasoning.expanded{-webkit-line-clamp:unset;display:block}.phase-insight-expand{color:var(--color-primary-500);font-size:var(--font-size-xs);cursor:pointer;background:0 0;border:none;margin-top:.125rem;padding:0}.phase-insight-expand:hover{color:var(--color-primary-600)}.phase-insights-empty{background:var(--color-success-light);border:1px solid var(--color-success-light);font-size:var(--font-size-sm);color:var(--color-success-dark);border-radius:.375rem;align-items:center;gap:.5rem;padding:.75rem;display:flex}.phase-activity-list{flex-direction:column;gap:0;display:flex}.phase-activity-item{border-bottom:1px solid var(--color-gray-100);align-items:flex-start;gap:.75rem;padding:.625rem 0;display:flex}.phase-activity-item:last-child{border-bottom:none}.phase-activity-dot{background:var(--color-primary-500);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:.375rem}.phase-activity-dot.dot-version{background:var(--color-success)}.phase-activity-content{flex:1;min-width:0}.phase-activity-text{font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:var(--line-height-snug)}.phase-activity-page-link{color:var(--color-primary-600);cursor:pointer;font-weight:var(--font-weight-medium)}.phase-activity-page-link:hover{text-decoration:underline}.phase-activity-state{font-weight:var(--font-weight-medium)}.phase-activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:.125rem}.phase-activity-comment{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.25rem;font-style:italic}.phase-activity-empty{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm);padding:1rem;font-style:italic}.phase-activity-toggle{width:100%;color:var(--color-primary-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:.25rem;padding:.5rem;display:block}.phase-activity-toggle:hover{color:var(--color-primary-600);background:var(--color-surface);border-radius:.25rem}.phase-overview-loading{color:var(--color-text-secondary);font-size:var(--font-size-sm);justify-content:center;align-items:center;padding:3rem;display:flex}.phase-overview-error{background:var(--color-danger-light);border:1px solid var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm);border-radius:.375rem;margin-bottom:1rem;padding:1rem}.onboarding{text-align:center;max-width:640px;padding:var(--spacing-12) 0;margin:0 auto}.onboarding-icon{width:72px;height:72px;margin:0 auto var(--spacing-6);background:linear-gradient(135deg, var(--color-primary-50), var(--color-primary-100));border-radius:var(--border-radius-xl);border:var(--border-width) solid var(--color-primary-200);color:var(--color-primary-500);justify-content:center;align-items:center;display:flex}.onboarding-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight);margin:0 0 var(--spacing-2)}.onboarding-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);max-width:420px;margin:0 auto var(--spacing-10)}.onboarding-steps{gap:var(--spacing-4);margin-bottom:var(--spacing-10);grid-template-columns:1fr 1fr 1fr;display:grid}.onboarding-step{background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-xl);padding:var(--spacing-6) var(--spacing-5);text-align:left;transition:all var(--transition-base)}.onboarding-step:hover{border-color:var(--color-border-dark);box-shadow:0 2px 8px #0000000a}.onboarding-step-number{border-radius:var(--border-radius-lg);width:32px;height:32px;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-3);justify-content:center;align-items:center;display:flex}.onboarding-step-1 .onboarding-step-number{background:var(--color-primary-50);color:var(--color-primary-500)}.onboarding-step-2 .onboarding-step-number{background:var(--color-success-light);color:var(--color-success)}.onboarding-step-3 .onboarding-step-number{background:var(--color-info-light);color:var(--color-info)}.onboarding-step-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:4px}.onboarding-step-desc{font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:var(--line-height-normal)}.onboarding-cta{font-size:var(--font-size-base);border-radius:var(--border-radius-lg);padding:12px 28px;box-shadow:0 2px 8px #0000001f}.onboarding-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000002e}@media (width<=768px){.onboarding{padding:var(--spacing-8) var(--spacing-4)}.onboarding-steps{grid-template-columns:1fr}}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--color-background);border-radius:.5rem;flex-direction:column;width:90%;max-width:500px;max-height:90vh;animation:.15s ease-out slideIn;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close-btn{font-size:var(--font-size-2xl);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:2rem;height:2rem;transition:all .15s;display:flex}.modal-close-btn:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.modal-body{flex:1;padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.modal-btn{border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:.375rem;padding:.5rem 1rem;transition:all .15s}.modal-btn-secondary{background:var(--color-background);color:var(--color-gray-700)}.modal-btn-secondary:hover{background:var(--color-gray-100)}.modal-btn-primary{background:var(--color-primary-500);color:#fff;border-color:var(--color-primary-500)}.modal-btn-primary:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}.modal-btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.modal-btn-danger:hover{background:var(--color-danger-dark);border-color:var(--color-danger-dark)}.modal-input{border:1px solid var(--color-gray-300);width:100%;font-size:var(--font-size-sm);box-sizing:border-box;border-radius:.375rem;padding:.5rem .75rem}.modal-input:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.modal-textarea{border:1px solid var(--color-gray-300);width:100%;min-height:80px;font-size:var(--font-size-sm);resize:vertical;box-sizing:border-box;border-radius:.375rem;padding:.5rem .75rem;font-family:inherit}.modal-textarea:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.modal-overlay{z-index:var(--z-index-modal-backdrop);padding:var(--spacing-4);animation:fadeIn var(--transition-fast);background-color:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background-color:var(--color-background);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-2xl);max-height:90vh;z-index:var(--z-index-modal);animation:slideUp var(--transition-base);flex-direction:column;width:100%;display:flex}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1000px}.modal-header{padding:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close{padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-secondary);transition:all var(--transition-base);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.modal-body{padding:var(--spacing-6);flex:1;overflow-y:auto}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--spacing-3);padding:var(--spacing-6);border-top:var(--border-width) solid var(--color-border);display:flex}.modal-body .checkbox-list{max-height:none;overflow-y:visible}.modal-body .checkbox-item{align-items:center;gap:var(--spacing-2);display:flex}@media (width<=640px){.modal-overlay{padding:var(--spacing-2)}.modal{max-height:95vh}.modal-header,.modal-body,.modal-footer{padding:var(--spacing-4)}}.textarea-container{gap:var(--spacing-2);flex-direction:column;display:flex}.textarea-full-width{width:100%}.textarea-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.textarea{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);background-color:var(--color-background);width:100%;color:var(--color-text-primary);transition:all var(--transition-base);resize:vertical;font-family:inherit;line-height:var(--line-height-relaxed);outline:none}.textarea:hover{border-color:var(--color-border-dark)}.textarea:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.textarea::placeholder{color:var(--color-text-tertiary)}.textarea:disabled{background-color:var(--color-surface);cursor:not-allowed;opacity:.6}.textarea-sm{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);min-height:80px}.textarea-md{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);min-height:100px}.textarea-lg{padding:var(--spacing-4) var(--spacing-5);font-size:var(--font-size-lg);min-height:120px}.textarea-error{border-color:var(--color-danger)}.textarea-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px #ef44441a}.textarea-error-message{font-size:var(--font-size-sm);color:var(--color-danger)}.textarea-help-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.psm-loading{padding:var(--spacing-12);text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.psm-form-override{gap:var(--spacing-5)}.psm-field,.psm-repos{gap:var(--spacing-2);flex-direction:column;display:flex}.psm-repo-item{align-items:center;gap:var(--spacing-2);background:var(--color-gray-50);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);padding:8px 12px;display:flex}.psm-repo-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);flex:1}.psm-repo-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-gray-100);border-radius:var(--border-radius-full);padding:2px 8px}.psm-repo-remove{color:var(--color-text-tertiary);cursor:pointer;font-size:var(--font-size-lg);border-radius:var(--border-radius-sm);width:24px;height:24px;transition:all var(--transition-base);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.psm-repo-remove:hover:not(:disabled){background:var(--color-danger-light);color:var(--color-danger)}.psm-add-repo{gap:var(--spacing-2);align-items:center;display:flex}.psm-add-repo-select{flex:1}.psm-add-repo-label{flex:none;width:140px}.psm-input,.psm-select{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-background);font-family:var(--font-family-sans);transition:all var(--transition-base);padding:8px 12px}.psm-input:focus,.psm-select:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.psm-input:disabled,.psm-select:disabled{background:var(--color-gray-50);cursor:not-allowed}.psm-select{cursor:pointer}.psm-footer{justify-content:flex-end;align-items:center;width:100%;display:flex}.psm-footer-right{gap:var(--spacing-2);display:flex}.project-form-page{max-width:720px;padding:var(--spacing-8);margin:0 auto}.project-form{gap:var(--spacing-6);flex-direction:column;display:flex}.form-label .required{color:var(--color-danger);margin-left:var(--spacing-1)}.form-help-text a{color:var(--color-primary-500);text-decoration:none}.form-help-text a:hover{text-decoration:underline}.type-cards-grid{gap:var(--spacing-3);margin-top:var(--spacing-1);grid-template-columns:repeat(auto-fill,minmax(180px,1fr));display:grid}.type-card{align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-3);background-color:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-base);text-align:center;flex-direction:column;display:flex}.type-card:hover{border-color:var(--color-primary-300,var(--color-border-dark));background-color:var(--color-surface-hover)}.type-card-selected{border-color:var(--color-primary-500);background-color:var(--color-primary-50,#6366f114);box-shadow:0 0 0 2px var(--color-primary-500)}.type-card-selected .type-card-name{color:var(--color-primary-600,var(--color-primary-500))}.type-card-selected:hover{border-color:var(--color-primary-500);background-color:var(--color-primary-50,#6366f11f)}.type-card-icon{color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.type-card-selected .type-card-icon{color:var(--color-primary-500)}.type-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.type-card-description{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.advanced-options{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);overflow:hidden}.advanced-options-toggle{align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-3) var(--spacing-4);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-base);background:0 0;border:none;display:flex}.advanced-options-toggle:hover{color:var(--color-text-primary);background-color:var(--color-surface)}.advanced-options-toggle>:last-child{margin-left:auto}.advanced-options-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary-500);background-color:var(--color-primary-50,#6366f11a);padding:1px var(--spacing-2);border-radius:var(--border-radius-sm)}.advanced-options-content{padding:0 var(--spacing-4) var(--spacing-4);border-top:var(--border-width) solid var(--color-border)}.advanced-options-content>.form-group{margin-top:var(--spacing-4)}.checkbox-list{gap:var(--spacing-2);padding:var(--spacing-4);background-color:var(--color-surface);border-radius:var(--border-radius-md);flex-direction:column;max-height:400px;display:flex;overflow-y:auto}.checkbox-item{align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3);border-radius:var(--border-radius-sm);cursor:pointer;transition:background-color var(--transition-base);display:flex}.checkbox-item input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--color-primary-500);flex-shrink:0;margin-top:2px}.checkbox-content{gap:var(--spacing-1);flex-direction:column;flex:1;display:flex}.checkbox-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.checkbox-description{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.form-actions{justify-content:flex-end;gap:var(--spacing-3);padding-top:var(--spacing-4);border-top:var(--border-width) solid var(--color-border);display:flex}@media (width<=768px){.project-form-page{max-width:100%}.type-cards-grid{grid-template-columns:repeat(2,1fr)}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}@media (width<=480px){.type-cards-grid{grid-template-columns:1fr}}.project-list-page{padding:var(--spacing-8);max-width:var(--container-xl);width:100%;margin:0 auto;overflow-x:hidden}.project-list-header{margin-bottom:var(--spacing-6);justify-content:space-between;align-items:flex-start;display:flex}.project-list-header-left{flex:1;min-width:0}.project-list-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:var(--letter-spacing-tight);margin:0}.project-list-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:4px 0 0}.project-list-header-right{gap:var(--spacing-3);flex-shrink:0;align-items:center;display:flex}.project-list-search{position:relative}.project-list-search-icon{color:var(--color-text-tertiary);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.project-list-search-input{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);width:240px;font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-background);transition:all var(--transition-base);font-family:var(--font-family-sans);outline:none;padding:8px 12px 8px 36px}.project-list-search-input:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.project-list-search-input::placeholder{color:var(--color-text-tertiary)}.project-list-stats{gap:var(--spacing-6);margin-bottom:var(--spacing-6);padding:var(--spacing-4) var(--spacing-5);background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);display:flex}.project-list-stat{align-items:center;gap:var(--spacing-2);display:flex}.project-list-stat-number{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.project-list-stat-blue{color:var(--color-primary-500)}.project-list-stat-green{color:var(--color-success)}.project-list-stat-amber{color:var(--color-warning)}.project-list-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.project-list-stat-divider{background:var(--color-border);align-self:stretch;width:1px}.projects-grid{gap:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));display:grid}.project-card-link{color:inherit;height:100%;text-decoration:none;display:block}.project-list-no-results{text-align:center;padding:var(--spacing-12) 0;font-size:var(--font-size-sm);color:var(--color-text-tertiary);grid-column:1/-1}@media (width<=1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (width<=768px){.project-list-page{padding:var(--spacing-4)}.project-list-header{gap:var(--spacing-4);flex-direction:column}.project-list-header-right{width:100%}.project-list-search{flex:1}.project-list-search-input{width:100%}.projects-grid{gap:var(--spacing-4);grid-template-columns:1fr}.project-list-stats{gap:var(--spacing-4);flex-wrap:wrap}.project-list-stat-divider{display:none}}.page-header{margin-bottom:var(--spacing-8);width:100%;max-width:100%}.page-header-breadcrumbs{margin-bottom:var(--spacing-4)}.page-header-content{justify-content:space-between;align-items:flex-start;gap:var(--spacing-6);width:100%;display:flex}.page-header-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0;line-height:var(--line-height-tight)}.page-header-description{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);max-width:700px;margin:0}.page-header-actions{align-items:center;gap:var(--spacing-3);flex-shrink:0;display:flex}@media (width<=768px){.page-header-content{flex-direction:column;align-items:stretch}.page-header-title{font-size:var(--font-size-2xl)}.page-header-actions{width:100%}.page-header-actions>*{flex:1}}.spinner{animation:1s linear infinite spin}.spinner-primary{color:var(--color-primary-500)}.spinner-white{color:var(--color-text-inverse)}.spinner-current{color:currentColor}.score-badge-container{align-items:center;display:inline-flex;position:relative}.score-badge{min-width:40px;height:28px;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-inverse);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:14px;justify-content:center;align-items:center;padding:0 8px;display:inline-flex}.score-badge.compact{min-width:28px;height:20px;font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;padding:0 5px;line-height:20px;display:inline-flex}.score-dot{cursor:pointer;border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.score-dot.processing{animation:2s infinite pulse;background-color:var(--color-text-secondary)!important}.score-badge.processing{background-color:var(--color-text-secondary);animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.score-badge.polling{position:relative}.polling-indicator{background-color:var(--color-background);border-radius:50%;width:6px;height:6px;animation:1.5s ease-in-out infinite pulse-dot;position:absolute;top:2px;right:2px}.score-badge.compact .polling-indicator{width:4px;height:4px;top:1px;right:1px}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.score-tooltip{background:var(--color-background);border:1px solid var(--color-border);z-index:10000;width:400px;max-width:90vw;max-height:calc(100vh - var(--tooltip-top,100px) - 20px);border-radius:8px;padding:16px;position:fixed;overflow:hidden auto;box-shadow:0 10px 25px #00000026}.tooltip-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.score-tooltip h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin:0}.tooltip-close{font-size:var(--font-size-2xl);line-height:var(--line-height-none);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;width:24px;height:24px;padding:0;transition:all .2s;display:flex}.tooltip-close:hover{background-color:var(--color-gray-100);color:var(--color-gray-700)}.score-criterion{margin-bottom:12px}.score-criterion:last-child{margin-bottom:0}.criterion-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.criterion-name{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm)}.criterion-score{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-inverse);border-radius:4px;padding:2px 6px}.criterion-reasoning{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-snug);margin:0}.left-panel{background:var(--color-surface);border-right:none;flex-direction:column;height:100%;display:flex}.phases-container{flex:1;overflow:hidden auto}.project-overview-nav-item{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:.375rem;align-items:center;padding:6px 1rem;transition:all .15s;display:flex;position:relative}.project-menu-container{align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.btn-project-menu{background:var(--color-gray-100);border:1px solid var(--color-gray-300);width:24px;height:24px;color:var(--color-text-secondary);cursor:pointer;line-height:var(--line-height-none);border-radius:.375rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.btn-project-menu:hover{background:var(--color-border);border-color:var(--color-text-tertiary);color:var(--color-gray-700)}.btn-project-menu:focus{outline:2px solid var(--color-primary-500);outline-offset:2px}.project-overview-nav-item:hover{background:var(--color-border)}.project-overview-nav-item.selected{background:var(--color-primary-100);border:1px solid var(--color-primary-500)}.project-overview-nav-item.selected:hover{background:var(--color-primary-200)}.phases-list{padding:0 0 .25rem}.phase-section{margin-bottom:.25rem}.phase-header{min-height:32px;font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:.375rem;align-items:center;gap:.5rem;padding:6px 1rem;transition:all .15s;display:flex}.phase-header:hover{background:var(--color-border)}.phase-header-content{-webkit-user-select:none;user-select:none;flex:1;align-items:center;gap:.5rem;display:flex}.phase-header.selected{background:var(--color-primary-100);border:1px solid var(--color-primary-500)}.phase-header.selected:hover{background:var(--color-primary-200)}.chevron{font-size:var(--font-size-xs);color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;display:flex}.phase-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);white-space:nowrap;text-overflow:ellipsis;height:20px;line-height:var(--line-height-none);flex:1;align-items:center;display:inline-flex;overflow:hidden}.pages-list{padding-left:0}.no-pages{font-size:var(--font-size-sm);color:var(--color-text-tertiary);padding:.75rem 1rem;font-style:italic}.page-item{cursor:pointer;min-height:32px;line-height:var(--line-height-none);border-radius:.375rem;justify-content:space-between;align-items:center;gap:.5rem;padding:6px 10px 6px calc(2rem + 14px);transition:all .15s;display:flex;position:relative}.page-type-group .page-item{padding-top:6px;padding-bottom:6px;padding-left:4.625rem}.page-item[draggable=true]{cursor:move}.page-item:hover{background:var(--color-border)}.page-item.selected{background:var(--color-primary-100);border:1px solid var(--color-primary-500)}.page-item.drag-over{border-top:2px solid var(--color-primary-500);margin-top:.25rem}.page-info{min-width:0;line-height:var(--line-height-none);flex:1;align-items:center;gap:.5rem;display:flex;overflow:hidden}.page-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;height:20px;line-height:var(--line-height-none);flex:0 auto;align-items:center;display:inline-flex;overflow:hidden}.state-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;border-radius:.25rem;flex:0 20 auto;align-items:center;min-width:0;height:20px;padding:2px 8px;display:inline-flex;overflow:hidden}.lock-icon{color:var(--color-text-secondary);flex:0 20 auto;align-items:center;min-width:0;display:inline-flex;overflow:hidden}.badge-not-started{background:var(--color-gray-100);color:var(--color-text-secondary)}.badge-in-progress,.badge-review{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-approved{background:var(--color-primary-100);color:var(--color-primary-700)}.badge-completed{background:var(--color-success-light);color:var(--color-success-dark)}.badge-final{background:var(--color-primary-100);color:var(--color-primary-800)}.badge-default{background:var(--color-gray-100);color:var(--color-text-secondary)}.page-type-group{margin:.125rem 0}.page-type-header{min-height:32px;font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:var(--font-weight-medium);line-height:var(--line-height-none);cursor:pointer;border-radius:.375rem;justify-content:space-between;align-items:center;gap:.5rem;padding:6px 10px 6px calc(2rem + 14px);transition:all .15s;display:flex}.page-type-header:hover{background:var(--color-border)}.page-type-header.selected{background:var(--color-primary-100);border:1px solid var(--color-primary-500)}.page-type-header.selected:hover{background:var(--color-primary-200)}.page-type-header-content{-webkit-user-select:none;user-select:none;min-width:0;line-height:var(--line-height-none);flex:1;align-items:center;gap:.5rem;display:flex;overflow:hidden}.doc-type-name{white-space:nowrap;text-overflow:ellipsis;height:20px;line-height:var(--line-height-none);flex:0 auto;align-items:center;display:inline-flex;overflow:hidden}.btn-add-doc{background:var(--color-gray-100);border:1px solid var(--color-gray-300);width:24px;height:24px;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-light);line-height:var(--line-height-none);cursor:pointer;border-radius:.25rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;transition:all .15s;display:inline-flex;position:relative}.btn-add-doc:before{content:"+";margin-top:-1px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.btn-add-doc:hover:not(:disabled){background:var(--color-border);border-color:var(--color-text-tertiary);color:var(--color-gray-700)}.btn-add-doc:disabled{opacity:.4;cursor:not-allowed;background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-tertiary)}.doc-type-pages{padding-left:0}.empty-page{opacity:.6;cursor:not-allowed}.empty-page:hover{background:0 0}.page-menu-container{align-items:center;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.btn-page-menu{width:24px;height:24px;color:var(--color-text-secondary);cursor:pointer;visibility:hidden;line-height:var(--line-height-none);background:0 0;border:none;border-radius:.25rem;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.page-item:hover .btn-page-menu,.btn-page-menu:focus{visibility:visible}.btn-page-menu:hover{background:var(--color-gray-300);color:var(--color-gray-700)}.btn-page-menu:focus{outline:2px solid var(--color-primary-500);outline-offset:2px}.page-menu-dropdown{background:var(--color-background);border:1px solid var(--color-border);z-index:9999;border-radius:.375rem;min-width:120px;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.menu-item{align-items:center;gap:var(--spacing-2);background:var(--color-background);text-align:left;width:100%;font-size:var(--font-size-sm);color:var(--color-gray-700);cursor:pointer;border:none;padding:.5rem .75rem;transition:background .15s;display:flex}.menu-item:hover{background:var(--color-gray-100)}.menu-item-danger{color:var(--color-danger-dark)}.menu-item-danger:hover{background:var(--color-danger-light)}.modal-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-background);border-radius:.5rem;min-width:400px;max-width:500px;padding:1.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 1rem}.modal-body{margin-bottom:1.5rem}.modal-body label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);margin-bottom:.5rem;display:block}.modal-body input{border:1px solid var(--color-gray-300);width:100%;font-size:var(--font-size-sm);box-sizing:border-box;border-radius:.375rem;padding:.625rem;font-family:inherit}.modal-body input:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.modal-body p{font-size:var(--font-size-sm);color:var(--color-gray-700);margin:0 0 .75rem}.modal-body p:last-child{margin-bottom:0}.warning-text{color:var(--color-danger-dark);font-weight:var(--font-weight-medium)}.modal-actions{justify-content:flex-end;gap:.75rem;display:flex}.btn-cancel,.btn-create,.btn-delete{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:.375rem;padding:.5rem 1rem;transition:all .15s}.btn-cancel{background:var(--color-background);border:1px solid var(--color-gray-300);color:var(--color-gray-700)}.btn-create{background:var(--color-primary-500);border:1px solid var(--color-primary-500);color:var(--color-text-inverse)}.btn-create:hover:not(:disabled){background:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-create:disabled{opacity:.5;cursor:not-allowed}.btn-delete{background:var(--color-danger-dark);border:1px solid var(--color-danger-dark);color:var(--color-text-inverse)}.btn-delete:hover{background:var(--color-danger-dark);border-color:var(--color-danger-dark)}.agent-indicator{color:var(--color-primary-500);flex-shrink:0;align-items:center;margin-left:4px;display:inline-flex}.agent-indicator.agent-active{animation:1.5s ease-in-out infinite agent-pulse}.agent-indicator.agent-error{color:var(--color-primary-700);opacity:.6}@keyframes agent-pulse{0%,to{opacity:1}50%{opacity:.4}}.version-history-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.version-history-modal{background:var(--color-background);border-radius:.5rem;flex-direction:column;width:90%;max-width:1200px;max-height:85vh;display:flex;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.version-history-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.version-history-header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.version-history-loading,.version-history-error{text-align:center;padding:2rem}.version-history-error{color:var(--color-danger)}.version-history-content{flex:1;grid-template-columns:350px 1fr;display:grid;overflow:hidden}.version-list{border-right:1px solid var(--color-border);padding:1.5rem;overflow-y:auto}.version-list h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);margin:0 0 1rem}.no-versions{color:var(--color-text-tertiary);font-size:var(--font-size-sm);font-style:italic}.version-item{border:1px solid var(--color-border);cursor:pointer;border-radius:.375rem;margin-bottom:.75rem;padding:1rem;transition:all .15s;position:relative}.version-item:hover{background:var(--color-gray-50);border-color:var(--color-primary-500)}.version-item.selected{background:var(--color-primary-50);border-color:var(--color-primary-500)}.version-item.draft-item{border:1.5px dashed var(--color-warning);background:var(--color-warning-light)}.version-item.draft-item:hover,.version-item.draft-item.selected{background:var(--color-warning-light);border-color:var(--color-warning-dark)}.draft-label{color:var(--color-warning-dark)}.version-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.version-number{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-base)}.version-date{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.version-author{font-size:var(--font-size-sm);color:var(--color-success-dark);font-weight:var(--font-weight-medium);margin-bottom:.25rem}.version-comment{font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:var(--line-height-snug);margin:.5rem 0 0}.btn-restore{background:var(--color-primary-500);color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:.25rem;margin-top:.75rem;padding:.375rem .75rem;transition:all .15s}.btn-restore:hover{background:var(--color-primary-600)}.version-preview{padding:1.5rem;overflow-y:auto}.preview-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;display:flex}.preview-header>div:first-child{flex:1}.preview-header h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 .25rem}.preview-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:block}.view-mode-toggle{border:1px solid var(--color-border);background:var(--color-gray-50);border-radius:.375rem;gap:.5rem;padding:.25rem;display:flex}.toggle-btn{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:.25rem;padding:.5rem 1rem;transition:all .15s}.toggle-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-gray-700)}.toggle-btn.active{background:var(--color-background);color:var(--color-primary-500);box-shadow:0 1px 2px #0000000d}.toggle-btn:disabled{opacity:.5;cursor:not-allowed}.preview-comment{background:var(--color-warning-light);border:1px solid var(--color-warning);font-size:var(--font-size-sm);color:var(--color-warning-dark);border-radius:.375rem;margin-bottom:1rem;padding:.75rem}.preview-comment strong{font-weight:var(--font-weight-semibold)}.preview-content{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-gray-700)}.preview-content h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:1.5rem 0 1rem}.preview-content h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:1.25rem 0 .75rem}.preview-content h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:1rem 0 .5rem}.preview-content code{background:var(--color-gray-100);font-family:var(--font-family-mono);border-radius:.25rem;padding:.125rem .375rem;font-size:.875em}.preview-content pre{background:var(--color-gray-800);color:var(--color-gray-100);border-radius:.375rem;margin:1rem 0;padding:1rem;overflow-x:auto}.preview-content pre code{color:inherit;background:0 0;padding:0}.no-content{color:var(--color-text-tertiary);text-align:center;padding:2rem;font-style:italic}.no-selection{height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-base);justify-content:center;align-items:center;display:flex}.version-history-actions{border-top:1px solid var(--color-border);justify-content:flex-end;padding:1.5rem;display:flex}.btn-close-modal{border:1px solid var(--color-gray-300);background:var(--color-background);color:var(--color-gray-700);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:.375rem;padding:.625rem 1.25rem;transition:all .15s}.btn-close-modal:hover{background:var(--color-gray-100)}.diff-view{font-family:var(--font-family-mono);font-size:var(--font-size-sm)}.diff-info{background:var(--color-gray-100);border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);color:var(--color-gray-700);border-radius:.375rem;margin-bottom:1rem;padding:.75rem}.diff-loading,.no-changes{color:var(--color-text-tertiary);text-align:center;font-style:italic;font-family:var(--font-family-sans);padding:2rem}.diff-content{background:var(--color-gray-50);border:1px solid var(--color-border);border-radius:.375rem;max-height:600px;overflow:auto}.diff-line{white-space:pre-wrap;word-break:break-all;line-height:var(--line-height-normal);border-left:3px solid #0000;padding:.25rem .75rem}.diff-header{background:var(--color-gray-100);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold);border-bottom:1px solid var(--color-border)}.diff-hunk{background:var(--color-primary-100);color:var(--color-primary-800);font-weight:var(--font-weight-semibold);border-bottom:1px solid var(--color-primary-300)}.diff-addition{background:var(--color-success-light);color:var(--color-success-dark);border-left-color:var(--color-success)}.diff-deletion{background:var(--color-danger-light);color:var(--color-danger-dark);border-left-color:var(--color-danger)}.diff-context{background:var(--color-background);color:var(--color-gray-700)}.markdown-toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-wrap:wrap;align-items:center;gap:.25rem;padding:.5rem;display:flex}.toolbar-btn{border:1px solid var(--color-gray-300);background:var(--color-background);cursor:pointer;width:1.75rem;height:1.75rem;color:var(--color-text-secondary);border-radius:.25rem;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.toolbar-btn:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.toolbar-btn:active{background:var(--color-border)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--color-background)}.toolbar-btn:disabled:hover{background:var(--color-background);border-color:var(--color-gray-300);color:var(--color-text-secondary)}.toolbar-btn.highlight{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-500)}.toolbar-btn.highlight:hover:not(:disabled){background:var(--color-primary-100);border-color:var(--color-primary-600);color:var(--color-primary-600)}.codemirror-editor-container{width:100%;height:100%;overflow:hidden}.codemirror-editor-container .cm-editor{height:100%}.cm-ai-highlight{background-color:#fb923c33;border-radius:2px;animation:5s ease-out forwards ai-highlight-fade}@keyframes ai-highlight-fade{0%{background-color:#fb923c33}70%{background-color:#fb923c33}to{background-color:#0000}}.file-browser-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.file-browser-modal{background:var(--color-background);box-shadow:var(--shadow-xl);border-radius:.5rem;flex-direction:column;width:90%;max-width:1000px;height:80vh;animation:.2s ease-out slideIn;display:flex}.file-browser-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.file-browser-header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.file-browser-content{flex:1;grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.file-list-section{border-right:1px solid var(--color-border);flex-direction:column;display:flex;overflow:hidden}.file-list-header{border-bottom:1px solid var(--color-border);padding:1rem 1.5rem}.file-list-header h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);margin:0}.file-list{flex:1;padding:.5rem;overflow-y:auto}.file-list-loading,.file-list-empty{text-align:center;color:var(--color-text-tertiary);padding:2rem}.file-list-item{cursor:pointer;border:2px solid #0000;border-radius:.375rem;align-items:center;gap:.75rem;padding:.75rem;transition:all .15s;display:flex}.file-list-item:hover{background:var(--color-surface)}.file-list-item.selected{background:var(--color-primary-50);border-color:var(--color-primary-500)}.file-list-item-icon{color:var(--color-text-secondary);flex-shrink:0}.file-list-item.selected .file-list-item-icon{color:var(--color-primary-500)}.file-list-item-info{flex:1;min-width:0}.file-list-item-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.file-list-item-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.125rem}.file-list-item-actions{opacity:0;gap:.25rem;transition:opacity .15s;display:flex}.file-list-item:hover .file-list-item-actions{opacity:1}.file-action-btn{border:1px solid var(--color-gray-300);background:var(--color-background);color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer;border-radius:.25rem;justify-content:center;align-items:center;padding:.25rem .5rem;transition:all .15s;display:flex}.file-action-btn:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.file-action-btn.delete{color:var(--color-danger-dark)}.file-action-btn.delete:hover{background:var(--color-danger-light);border-color:var(--color-danger-dark)}.file-preview-section{flex-direction:column;display:flex;overflow:hidden}.file-preview-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.file-preview-header h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);margin:0}.preview-actions{gap:.5rem;display:flex}.btn-preview-action{border:1px solid var(--color-gray-300);background:var(--color-background);color:var(--color-gray-700);font-size:var(--font-size-sm);cursor:pointer;border-radius:.25rem;align-items:center;gap:.375rem;padding:.375rem .75rem;transition:all .15s;display:flex}.btn-preview-action:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary)}.file-preview-content{flex:1;justify-content:center;align-items:center;padding:1.5rem;display:flex;overflow:auto}.no-preview{color:var(--color-text-tertiary);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.file-info-large{text-align:center}.file-info-large svg{color:var(--color-text-tertiary);margin-bottom:1rem}.file-info-large .filename{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);word-break:break-word;margin:.5rem 0}.file-info-large .file-size,.file-info-large .file-type{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:.25rem 0}.image-preview{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.image-preview img{object-fit:contain;max-width:100%;max-height:100%;box-shadow:var(--shadow-md);border-radius:.375rem}.manage-context-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.15s ease-out fadeIn;display:flex;position:fixed;inset:0}.manage-context-modal{background:var(--color-background);box-shadow:var(--shadow-xl);border-radius:.5rem;flex-direction:column;width:90%;max-width:1000px;height:80vh;animation:.2s ease-out slideIn;display:flex;overflow:hidden}.manage-context-header{border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:1.5rem;padding:1rem 1.5rem;display:flex}.manage-context-header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap;margin:0}.manage-context-tabs{flex:1;gap:0;display:flex}.manage-context-tab{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 1rem;transition:all .15s}.manage-context-tab:hover{color:var(--color-text-primary)}.manage-context-tab.active{color:var(--color-primary-500);border-bottom-color:var(--color-primary-500);font-weight:var(--font-weight-semibold)}.manage-context-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;margin-left:auto;padding:.25rem;display:flex}.manage-context-close:hover{color:var(--color-text-primary);background:var(--color-surface)}.manage-context-body{flex:1;overflow:hidden}.manage-context-files-wrapper{height:100%}.manage-context-files-wrapper .file-browser-overlay{background:0 0;height:100%;animation:none;position:static}.manage-context-files-wrapper .file-browser-modal{width:100%;max-width:none;height:100%;box-shadow:none;border-radius:0;animation:none}.manage-context-files-wrapper .file-browser-header{display:none}.manage-context-sources{grid-template-columns:1fr 1fr;height:100%;display:grid;overflow:hidden}.manage-context-sources-list{border-right:1px solid var(--color-border);flex-direction:column;display:flex;overflow:hidden}.manage-context-search{border-bottom:1px solid var(--color-border);flex-shrink:0;padding:.75rem 1rem}.manage-context-search-input{width:100%;font-size:var(--font-size-sm);border:1px solid var(--color-border);box-sizing:border-box;background:var(--color-background);color:var(--color-text-primary);border-radius:.375rem;outline:none;padding:.5rem .75rem}.manage-context-search-input:focus{border-color:var(--color-primary-500);box-shadow:0 0 0 2px #1e36501a}.manage-context-search-input::placeholder{color:var(--color-text-tertiary)}.manage-context-sources-scroll{flex:1;padding:.5rem;overflow-y:auto}.manage-context-section{margin-bottom:.5rem}.manage-context-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-tertiary);align-items:center;gap:.375rem;padding:.375rem .5rem;display:flex}.manage-context-source-item{cursor:pointer;border:2px solid #0000;border-radius:.375rem;align-items:center;gap:.5rem;padding:.5rem .75rem;transition:all .15s;display:flex}.manage-context-source-item:hover{background:var(--color-surface)}.manage-context-source-item.selected{background:var(--color-primary-50);border-color:var(--color-primary-500)}.manage-context-source-item.search-result:hover{background:var(--color-surface)}.manage-context-source-title{font-size:var(--font-size-sm);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.manage-context-delete-btn{cursor:pointer;color:var(--color-text-tertiary);opacity:0;background:0 0;border:none;flex-shrink:0;align-items:center;padding:.125rem;transition:opacity .15s;display:flex}.manage-context-source-item:hover .manage-context-delete-btn{opacity:1}.manage-context-delete-btn:hover{color:var(--color-danger-dark)}.manage-context-add-btn{font-size:var(--font-size-xs);border:1px solid var(--color-primary-500);color:var(--color-primary-500);cursor:pointer;font-weight:var(--font-weight-medium);background:0 0;border-radius:.25rem;flex-shrink:0;padding:.125rem .5rem;transition:all .15s}.manage-context-add-btn:hover:not(:disabled){background:var(--color-primary-50)}.manage-context-add-btn:disabled{opacity:.5;cursor:default}.manage-context-provider-badge{font-size:10px;font-weight:var(--font-weight-semibold);background:var(--color-surface);color:var(--color-text-secondary);border-radius:3px;flex-shrink:0;padding:1px 4px}.manage-context-url-hint{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;padding:.75rem 1rem}.manage-context-url-hint strong{color:var(--color-text-primary)}.manage-context-empty{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm);padding:1.5rem}.manage-context-sources-preview{flex-direction:column;display:flex;overflow:hidden}.manage-context-preview-empty{height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-sm);justify-content:center;align-items:center;display:flex}.manage-context-preview-content{padding:1.5rem;overflow-y:auto}.manage-context-preview-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);word-break:break-word;margin:0 0 1.5rem}.manage-context-preview-field{margin-bottom:1rem}.manage-context-preview-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-tertiary);margin-bottom:.25rem;display:block}.manage-context-preview-url{font-size:var(--font-size-sm);color:var(--color-primary-500);word-break:break-all;align-items:center;gap:.25rem;text-decoration:none;display:inline-flex}.manage-context-preview-url:hover{text-decoration:underline}.manage-context-status-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);letter-spacing:.04em}.page-comments-container{background:var(--color-surface);border-top:1px solid var(--color-border);box-sizing:border-box;height:100%;padding:16px;overflow-y:auto;container:comments-panel/inline-size}.comments-section{margin-bottom:24px}.comments-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);align-items:center;gap:8px;margin-bottom:12px;padding:8px 0;display:flex}.comments-section-title.collapsible{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.comments-section-title.collapsible:hover{color:var(--color-gray-800)}.comments-list{flex-direction:column;gap:12px;display:flex}.comment-item{background:var(--color-background);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;padding:12px 16px;transition:all .2s;position:relative}.comment-item:hover{box-shadow:var(--shadow-md);border-color:var(--color-gray-300)}.comment-item.selected{border-color:var(--color-primary-500);background:var(--color-primary-50);box-shadow:var(--shadow-focus)}.comment-item.ai-comment{border-left:4px solid var(--color-primary-400)}.comment-item.user-comment{border-left:4px solid var(--color-primary-500)}.comment-item.agent-comment{border-left:4px solid var(--color-primary-500);background:var(--color-primary-50)}.comment-source{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic}.comment-item.reply-comment{background:var(--color-gray-100);border-left:3px solid var(--color-text-tertiary);margin-top:8px}.comment-item.resolved{opacity:.6;background:var(--color-surface);border-color:var(--color-gray-300)}.comment-item.resolved:hover{opacity:.8}.comment-header{font-size:var(--font-size-xs);justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.comment-author{font-weight:var(--font-weight-semibold);color:var(--color-gray-800);align-items:center;gap:4px;display:flex}.comment-time{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.comment-selected-text{background:var(--color-warning-light);border-left:3px solid var(--color-warning);font-size:var(--font-size-sm);color:var(--color-warning-dark);border-radius:4px;margin:8px 0;padding:6px 10px;font-style:italic}.comment-text{color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:var(--line-height-normal);word-wrap:break-word;margin:8px 0}.comment-actions{border-top:1px solid var(--color-border);gap:8px;margin-top:12px;padding-top:8px;display:flex}.btn-comment-action{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 10px;transition:all .2s;display:flex}.btn-comment-action:hover{background:var(--color-gray-100)}.btn-comment-action.reply{color:var(--color-primary-500)}.btn-comment-action.reply:hover{background:var(--color-primary-50);color:var(--color-primary-600)}.btn-comment-action.resolve{color:var(--color-success)}.btn-comment-action.resolve:hover{background:var(--color-success-light);color:var(--color-success-dark)}.btn-comment-action.reopen{color:var(--color-warning)}.btn-comment-action.reopen:hover{background:var(--color-warning-light);color:var(--color-warning-dark)}.btn-comment-action.delete{color:var(--color-danger)}.btn-comment-action.delete:hover{background:var(--color-danger-light);color:var(--color-danger-dark)}.reply-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-top:12px;padding:12px}.reply-textarea{border:1px solid var(--color-gray-300);width:100%;font-size:var(--font-size-sm);resize:vertical;border-radius:6px;min-height:60px;margin-bottom:8px;padding:10px;font-family:inherit;transition:border-color .2s}.reply-textarea:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.reply-form-actions{justify-content:flex-end;gap:8px;display:flex}.btn-reply-cancel,.btn-reply-submit{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:4px;padding:6px 12px;transition:all .2s;display:flex}.btn-reply-cancel{background:var(--color-gray-100);color:var(--color-text-secondary)}.btn-reply-cancel:hover{background:var(--color-border);color:var(--color-gray-700)}.btn-reply-submit{background:var(--color-primary-500);color:var(--color-text-inverse)}.btn-reply-submit:hover{background:var(--color-primary-600)}.comment-replies{border-left:2px solid var(--color-border);margin-top:8px;padding-left:16px}.resolved-section .comments-section-title{color:var(--color-text-secondary)}@container (width<=350px){.btn-comment-action .btn-text{display:none}.btn-comment-action{justify-content:center;min-width:32px;padding:6px 8px}}@supports not (container-type:inline-size){@media (width<=350px){.btn-comment-action .btn-text{display:none}.btn-comment-action{justify-content:center;min-width:32px;padding:6px 8px}}}@media (width<=768px){.page-comments-container{padding:12px}.comment-item{padding:10px 12px}.comment-actions{flex-wrap:wrap}.btn-comment-action{font-size:var(--font-size-xs)}}.comment-form-overlay{z-index:1000;background:#0000004d;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.comment-form{background:var(--color-background);border-radius:8px;flex-direction:column;width:400px;max-width:90vw;max-height:80vh;display:flex;position:absolute;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 10px 25px #0003}.comment-form-header{border-bottom:1px solid var(--color-border);background:var(--color-surface);justify-content:space-between;align-items:center;padding:1rem;display:flex}.comment-form-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);align-items:center;gap:.5rem;display:flex}.comment-form-close{width:1.5rem;height:1.5rem;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .2s;display:flex}.comment-form-close:hover{background:var(--color-border);color:var(--color-text-primary)}.comment-form-selected-text{background:var(--color-primary-50);border-left:3px solid var(--color-primary-500);font-size:var(--font-size-sm);color:var(--color-primary-800);border-radius:4px;margin:1rem;padding:.75rem 1rem;font-style:italic}.comment-form form{flex-direction:column;gap:.75rem;padding:0 1rem 1rem;display:flex}.comment-form-textarea{border:1px solid var(--color-gray-300);width:100%;font-size:var(--font-size-sm);resize:vertical;border-radius:6px;min-height:80px;padding:.75rem;font-family:inherit;transition:all .2s}.comment-form-textarea:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.comment-form-actions{justify-content:flex-end;gap:.5rem;display:flex}.btn-cancel,.btn-submit{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:6px;padding:.5rem 1rem;transition:all .2s}.btn-cancel{background:var(--color-gray-100);color:var(--color-gray-700)}.btn-cancel:hover{background:var(--color-border)}.btn-submit{background:var(--color-primary-500);color:var(--color-text-inverse)}.btn-submit:hover:not(:disabled){background:var(--color-primary-600)}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.comment-form-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-align:right}.comment-form-draggable{cursor:grab;-webkit-user-select:none;user-select:none}.comment-form-draggable:active{cursor:grabbing}.panel-header{border-bottom:1px solid var(--color-border);box-sizing:border-box;flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:flex-start;gap:.25rem 1rem;width:100%;padding:.75rem 1.5rem;display:flex}.panel-header.sticky-header{z-index:10;background:var(--color-background);will-change:transform;position:sticky;top:0}.panel-header .page-title-section{flex:auto;min-width:0}.panel-header .page-title-section h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;overflow:hidden}.title-with-state{align-items:center;gap:1rem;min-width:0;margin-bottom:.25rem;display:flex}.state-select{border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);background:var(--color-background);cursor:pointer;border-radius:.375rem;flex-shrink:0;padding:.375rem .625rem}.state-select:disabled{background:var(--color-gray-100);cursor:not-allowed}.page-metadata{font-size:var(--font-size-sm);color:var(--color-text-secondary);gap:.5rem;display:flex}.page-actions{flex-flow:row-reverse wrap;flex-shrink:0;justify-content:flex-start;align-items:center;gap:.5rem;margin-left:auto;display:flex}.page-actions-group{align-items:center;gap:.5rem;display:flex}.panel-actions-divider{background:var(--color-border);width:1px;height:18px;margin:0 var(--spacing-1)}@container middle-panel (width<=600px){.panel-header{padding:.5rem 1rem}.title-with-state{gap:.5rem}.panel-header .page-title-section h2{font-size:var(--font-size-base)}.state-select{font-size:var(--font-size-xs);padding:.25rem .375rem}.page-metadata{flex-wrap:wrap}.page-actions,.page-actions-group{gap:.25rem}}@container middle-panel (width<=450px){.panel-header .page-title-section{flex:100%}}@container middle-panel (width<=400px){.page-metadata{display:none}}@supports not (container-type:inline-size){@media (width<=1024px){.panel-header{padding:.5rem 1rem}.title-with-state{gap:.5rem}.panel-header .page-title-section h2{font-size:var(--font-size-base)}.state-select{font-size:var(--font-size-xs);padding:.25rem .375rem}.page-metadata{flex-wrap:wrap}.page-actions,.page-actions-group{gap:.25rem}}@media (width<=768px){.panel-header .page-title-section{flex:100%}}@media (width<=640px){.page-metadata{display:none}}}.agent-activity-panel{border-top:1px solid var(--color-border);background:var(--color-primary-50);z-index:5;flex-direction:column;flex-shrink:0;display:flex;position:sticky;bottom:0}.agent-activity-panel.expanded{flex-shrink:0;overflow:hidden}.agent-resize-handle{cursor:row-resize;background:var(--color-primary-50);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:center;align-items:center;height:6px;display:flex}.agent-resize-handle:hover{background:var(--color-primary-100)}.agent-resize-grip{background:var(--color-primary-300);border-radius:1px;width:32px;height:2px}.agent-resize-handle:hover .agent-resize-grip{background:var(--color-primary-500)}.agent-activity-header{cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--color-primary-50);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.agent-activity-header:hover{background:var(--color-primary-100)}.agent-activity-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-500);align-items:center;gap:6px;display:flex}.activity-count{background:var(--color-primary-500);color:var(--color-text-inverse);font-size:var(--font-size-xs);border-radius:10px;padding:0 6px;line-height:18px}.agent-activity-list{flex:1;padding:4px 0;overflow-y:auto}.activity-loading,.activity-empty{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm);padding:12px}.activity-item{font-size:var(--font-size-sm);border-bottom:1px solid var(--color-primary-100);align-items:flex-start;gap:8px;padding:6px 12px;display:flex}.activity-item:last-child{border-bottom:none}.activity-icon{color:var(--color-primary-500);flex-shrink:0;margin-top:2px}.activity-item.activity-error .activity-icon{color:var(--color-primary-700);opacity:.6}.activity-item.activity-reasoning .activity-icon{color:var(--color-text-secondary)}.activity-content{flex-direction:column;gap:2px;min-width:0;display:flex}.activity-summary{color:var(--color-gray-700);line-height:var(--line-height-snug);word-break:break-word;cursor:pointer}.activity-summary.clamped{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.activity-summary.expanded{display:block}.activity-item.activity-error .activity-summary{color:var(--color-primary-700)}.activity-item.activity-reasoning .activity-summary{color:var(--color-text-secondary);font-style:italic}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.agent-header-right{align-items:center;gap:8px;display:flex}.agent-token-usage{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary-400)}.middle-panel{background:var(--color-background);flex-direction:column;width:100%;min-width:0;height:100%;display:flex;overflow:hidden;container:middle-panel/inline-size}.middle-panel.empty{justify-content:center;align-items:center}.middle-panel.scroll-header{overflow-y:auto}.middle-panel.scroll-header .page-content{flex:1 0 auto;overflow:visible}.middle-panel.scroll-header .markdown-view{height:auto;overflow-y:visible}.middle-panel.scroll-header .panel-header.sticky-header{z-index:10;background:var(--color-background);will-change:transform;position:sticky;top:0}.empty-state{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-lg)}.page-title-section h2.editable-title{cursor:pointer;border-radius:.25rem;padding:.25rem .5rem;transition:background .15s}.page-title-section h2.editable-title:hover{background:var(--color-gray-100)}.page-title-section .title-input{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border:2px solid var(--color-primary-500);border-radius:.25rem;outline:none;width:auto;min-width:200px;margin:0;padding:.25rem .5rem;font-family:inherit}.version-link{cursor:pointer;color:var(--color-primary-500);align-items:center;gap:.25rem;transition:all .15s;display:inline-flex}.version-link:hover{color:var(--color-primary-600);text-decoration:underline}.draft-indicator{color:var(--color-warning);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:help}.locked-indicator{color:var(--color-danger-dark);cursor:pointer;align-items:center;display:inline-flex;position:relative}.lock-tooltip{visibility:hidden;background:var(--color-warning-light);border:1px solid var(--color-warning);min-width:250px;max-width:350px;color:var(--color-warning-dark);font-size:var(--font-size-sm);line-height:var(--line-height-normal);font-weight:var(--font-weight-normal);white-space:normal;word-wrap:break-word;z-index:1000;pointer-events:none;border-radius:.375rem;padding:.75rem 1rem;position:absolute;top:calc(100% + .75rem);left:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.lock-tooltip:before{content:"";border:5px solid #0000;border-bottom-color:var(--color-warning);position:absolute;bottom:100%;left:.5rem}.locked-indicator:hover .lock-tooltip{visibility:visible}.workspace-icon-btn{border:1px solid var(--color-gray-300);background:var(--color-background);cursor:pointer;width:2rem;height:2rem;color:var(--color-text-secondary);border-radius:.375rem;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex;position:relative}.workspace-icon-btn:hover:not(:disabled){background:var(--color-gray-100);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.workspace-icon-btn:disabled{opacity:.5;cursor:not-allowed}.workspace-icon-btn.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-500)}.comment-badge{background:var(--color-danger);min-width:16px;height:16px;color:var(--color-text-inverse);font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);line-height:var(--line-height-none);border:2px solid var(--color-background);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;display:flex;position:absolute;top:-6px;right:-6px;box-shadow:0 1px 3px #0003}.workspace-icon-btn.save-version-btn{background:var(--color-primary-500);border-color:var(--color-primary-500);color:var(--color-text-inverse)}.workspace-icon-btn.save-version-btn:hover:not(:disabled){background:var(--color-primary-600);border-color:var(--color-primary-600);color:var(--color-text-inverse)}.view-mode-selector{background:var(--color-gray-100);border-radius:.375rem;gap:.25rem;padding:.25rem;display:flex}.mode-btn{cursor:pointer;width:2rem;height:2rem;color:var(--color-text-secondary);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.mode-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text-primary)}.mode-btn.active{background:var(--color-background);color:var(--color-primary-500);box-shadow:0 1px 2px #0000000d}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.dependency-warning{background:var(--color-warning-light);border-bottom:1px solid var(--color-warning);color:var(--color-warning-dark);font-size:var(--font-size-sm);padding:1rem 1.5rem}.page-error{background:var(--color-danger-light);border-bottom:1px solid var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.page-content{flex:auto;width:100%;min-width:0;overflow:hidden}.editor-only{box-sizing:border-box;flex-direction:column;height:100%;padding:0;display:flex;position:relative;overflow:hidden}.editor-container{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.split-editor{width:100%;min-width:0;height:100%;overflow:hidden}.preview-resize-handle{background:var(--color-border);cursor:col-resize;width:4px;transition:background .15s;position:relative}.preview-resize-handle:hover{background:var(--color-primary-500)}.preview-resize-handle[data-resize-handle-active]{background:var(--color-primary-600)}.editor-section,.preview-section{box-sizing:border-box;width:100%;min-width:0;height:100%;position:relative;overflow:hidden}.editor-section{flex-direction:column;padding:0;display:flex}.editor-section .editor-container{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.split-editor .preview-section{padding:1.5rem;overflow:hidden auto}.editor-container .codemirror-editor-container{flex:1;overflow:hidden}.editor-container .cm-editor{height:100%}.editor-container .cm-editor .cm-content{padding:1rem 1.5rem}.editor-container.dragging{opacity:.5}.editor-container.ai-editing .cm-editor{background-color:var(--color-warning-light);opacity:.9}.editor-container.ai-editing .cm-content{color:var(--color-warning-dark);cursor:not-allowed}.drag-overlay{border:2px dashed var(--color-primary-500);pointer-events:none;z-index:10;background:#3b82c41a;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.drag-overlay-content{text-align:center;color:var(--color-primary-500)}.drag-overlay-content svg{margin-bottom:.5rem}.drag-overlay-content p{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);margin:0}.upload-overlay{z-index:20;background:#ffffffe6;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.upload-spinner{background:var(--color-background);font-size:var(--font-size-sm);color:var(--color-text-secondary);border-radius:.375rem;padding:1rem 2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.auto-save-indicator{font-size:var(--font-size-xs);color:var(--color-text-secondary);border:1px solid var(--color-border);pointer-events:none;background:#ffffffe6;border-radius:.25rem;align-items:center;gap:.375rem;padding:.25rem .5rem;display:flex;position:absolute;bottom:1.5rem;right:1.5rem}.sync-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.sync-saved{background-color:var(--color-success)}.sync-saving{background-color:var(--color-warning);animation:1s ease-in-out infinite pulse-dot}.sync-error{background-color:var(--color-danger)}.markdown-preview{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-gray-700);box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word;width:100%}.markdown-preview>*,.markdown-view>*{max-width:100%}.markdown-view{box-sizing:border-box;width:100%;min-width:0;height:100%;font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-gray-700);overflow-wrap:break-word;word-wrap:break-word;padding:1.5rem;overflow:hidden auto}.ai-edit-highlight-line{background-color:#fb923c26;border-radius:3px;animation:5s ease-out forwards ai-line-highlight-fade}@keyframes ai-line-highlight-fade{0%{background-color:#fb923c26}70%{background-color:#fb923c26}to{background-color:#0000}}.markdown-preview h1,.markdown-view h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:1.5rem 0 1rem}.markdown-preview h2,.markdown-view h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:1.25rem 0 .75rem}.markdown-preview h3,.markdown-view h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:1rem 0 .5rem}.markdown-preview code,.markdown-view code{background:var(--color-gray-100);font-family:var(--font-family-mono);border-radius:.25rem;padding:.125rem .375rem;font-size:.875em}.markdown-preview pre,.markdown-view pre{background:var(--color-gray-800);color:var(--color-gray-100);border-radius:.375rem;max-width:100%;margin:1rem 0;padding:1rem;overflow-x:auto}.markdown-preview pre code,.markdown-view pre code{color:inherit;background:0 0;padding:0}.markdown-preview ul,.markdown-view ul{margin:.75rem 0;padding-left:1.5rem;list-style-type:disc;list-style-position:outside}.markdown-preview ol,.markdown-view ol{margin:.75rem 0;padding-left:1.5rem;list-style-type:decimal;list-style-position:outside}.markdown-preview li,.markdown-view li{margin:.25rem 0;padding-left:.25rem}.markdown-preview ul ul,.markdown-view ul ul{margin:.25rem 0;list-style-type:circle}.markdown-preview ul ul ul,.markdown-view ul ul ul{list-style-type:square}.markdown-preview ol ol,.markdown-view ol ol{margin:.25rem 0;list-style-type:lower-alpha}.markdown-preview ol ol ol,.markdown-view ol ol ol{list-style-type:lower-roman}.markdown-preview blockquote,.markdown-view blockquote{border-left:4px solid var(--color-border);color:var(--color-text-secondary);margin:1rem 0;padding-left:1rem}.markdown-preview table,.markdown-view table{border-collapse:collapse;width:100%;max-width:100%;margin:1rem 0;display:block;overflow-x:auto}.markdown-preview th,.markdown-view th,.markdown-preview td,.markdown-view td{border:1px solid var(--color-border);text-align:left;padding:.5rem}.markdown-preview th,.markdown-view th{background:var(--color-surface);font-weight:var(--font-weight-semibold)}.view-with-comments{width:100%;min-width:0;height:100%;overflow:hidden}.floating-comment-btn{background:var(--color-primary-500);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;z-index:100;border:none;border-radius:6px;align-items:center;gap:.375rem;padding:.5rem .875rem;transition:all .2s;animation:.2s ease-out fadeInUp;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.floating-comment-btn:hover{background:var(--color-primary-600);transform:translate(-50%)translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toolbar-separator{background:var(--color-border);width:1px;height:24px;margin:0 4px}.agent-toggle-btn{border-radius:6px;align-items:center;gap:4px;transition:all .2s;display:flex;padding:4px 8px!important}.agent-toggle-btn.agent-active{background:var(--color-primary-500)!important;color:var(--color-text-inverse)!important}.agent-toggle-btn.agent-working{animation:1.5s ease-in-out infinite agent-pulse}.agent-state-indicator{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background:var(--color-primary-50);color:var(--color-primary-500);white-space:nowrap;border-radius:10px;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.agent-state-indicator.agent-working{background:var(--color-primary-100);animation:1.5s ease-in-out infinite agent-pulse}.agent-state-indicator.agent-error{background:var(--color-primary-100);color:var(--color-primary-700)}.agent-state-indicator.agent-clickable{cursor:pointer}.agent-state-indicator.agent-clickable:hover{opacity:.8}.agent-state-label{line-height:var(--line-height-none)}.agent-confirm-modal{max-width:440px}.agent-confirm-modal h3{font-size:var(--font-size-lg);margin:0 0 12px}.agent-confirm-modal p{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:8px 0}.agent-confirm-modal ul{font-size:var(--font-size-sm);color:var(--color-gray-600);margin:8px 0;padding-left:20px}.agent-confirm-modal li{margin:4px 0}.agent-confirm-modal .modal-actions{justify-content:flex-end;gap:8px;margin-top:16px;display:flex}.quick-reply-tabs{border:1px solid var(--color-border);background:var(--color-background);border-radius:.5rem;flex-direction:column;margin-bottom:.5rem;display:flex;overflow:hidden}.quick-reply-tab-bar{border-bottom:1px solid var(--color-border);background:var(--color-surface);display:flex}.quick-reply-tab{border:none;border-right:1px solid var(--color-border);font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:0 0;flex:1;padding:.5rem .625rem;transition:all .15s;overflow:hidden}.quick-reply-tab:last-child{border-right:none}.quick-reply-tab:hover:not(:disabled){background:var(--color-gray-100);color:var(--color-gray-700)}.quick-reply-tab.active{background:var(--color-background);color:var(--color-primary-700);border-bottom:2px solid var(--color-primary-500);margin-bottom:-1px}.quick-reply-tab.answered{font-weight:var(--font-weight-bold);color:var(--color-gray-700)}.quick-reply-tab.answered.active{color:var(--color-primary-700)}.quick-reply-tab:disabled{opacity:.5;cursor:not-allowed}.quick-reply-tab-content{flex-direction:column;gap:.375rem;padding:.625rem;display:flex}.quick-reply-question{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);line-height:var(--line-height-snug);padding:0 .125rem}.quick-reply-chip{border:1px solid var(--color-gray-300);background:var(--color-surface);color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:var(--line-height-snug);cursor:pointer;text-align:left;border-radius:.5rem;gap:.375rem;width:100%;padding:.5rem .625rem;transition:all .15s;display:flex}.quick-reply-chip:hover:not(:disabled){background:var(--color-primary-50);border-color:var(--color-primary-300);color:var(--color-primary-700)}.quick-reply-chip:active:not(:disabled){background:var(--color-primary-100);border-color:var(--color-primary-400)}.quick-reply-chip.selected{background:var(--color-primary-100);border-color:var(--color-primary-500);color:var(--color-primary-800)}.quick-reply-chip:disabled{opacity:.5;cursor:not-allowed}.chip-label{font-weight:var(--font-weight-semibold);flex-shrink:0}.chip-text{font-weight:var(--font-weight-medium)}.quick-reply-freetext{align-items:center;gap:.375rem;display:flex}.freetext-input{border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);color:var(--color-gray-700);background:var(--color-background);border-radius:.5rem;outline:none;flex:1;padding:.5rem .625rem;transition:border-color .15s}.freetext-input:focus{border-color:var(--color-primary-300)}.freetext-input::placeholder{color:var(--color-text-tertiary)}.freetext-send{border:1px solid var(--color-primary-500);background:var(--color-primary-500);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border-radius:.5rem;flex-shrink:0;padding:.5rem .75rem;transition:all .15s}.freetext-send:hover:not(:disabled){background:var(--color-primary-600)}.freetext-send:disabled{opacity:.5;cursor:not-allowed}.quick-reply-submit{background:var(--color-success-dark);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:.375rem;margin:0 .625rem .625rem;padding:.5rem .75rem;transition:background .15s}.quick-reply-submit:hover:not(:disabled){background:var(--color-success-dark)}.quick-reply-submit:disabled{opacity:.5;cursor:not-allowed}.plan-card{border:1px solid var(--color-border);background:var(--color-surface);border-radius:.5rem;margin-bottom:.75rem;overflow:hidden}.plan-card-body{max-height:300px;padding:.75rem;overflow-y:auto}.plan-card-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-primary);margin-bottom:.25rem}.plan-card-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:.625rem}.plan-card-section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wider);color:var(--color-text-tertiary);margin-top:.5rem;margin-bottom:.25rem}.plan-steps{flex-direction:column;gap:.375rem;display:flex}.plan-step{font-size:var(--font-size-sm);line-height:var(--line-height-snug);align-items:baseline;gap:.375rem;display:flex}.plan-step-number{color:var(--color-text-tertiary);font-size:var(--font-size-xs);text-align:right;flex-shrink:0;min-width:1rem}.plan-action-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:lowercase;border-radius:9999px;flex-shrink:0;padding:.0625rem .375rem}.plan-action-rewrite{background:var(--color-warning-light);color:var(--color-warning-dark)}.plan-action-fill_in{background:var(--color-primary-50);color:var(--color-primary-700)}.plan-action-update{background:var(--color-success-light);color:var(--color-success-dark)}.plan-action-add{background:var(--color-primary-100);color:var(--color-primary-700)}.plan-action-remove{background:var(--color-danger-light);color:var(--color-danger-dark)}.plan-step-section{font-weight:var(--font-weight-semibold);color:var(--color-gray-700);flex-shrink:0}.plan-step-desc{color:var(--color-text-secondary)}.plan-card-unchanged,.plan-card-context,.plan-card-remarks{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-snug)}.plan-actions-bar{border-top:1px solid var(--color-border);background:var(--color-background);padding:.5rem .75rem}.plan-actions-row{align-items:center;gap:.5rem;display:flex}.plan-btn{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;border:none;border-radius:.375rem;padding:.375rem .75rem;transition:all .15s}.plan-btn:disabled{opacity:.5;cursor:not-allowed}.plan-btn-approve{background:var(--color-success-dark);color:var(--color-text-inverse)}.plan-btn-approve:hover:not(:disabled){background:var(--color-success-dark)}.plan-btn-reject{background:var(--color-background);color:var(--color-danger-dark);border:1px solid var(--color-danger-light)}.plan-btn-reject:hover:not(:disabled){background:var(--color-danger-light);border-color:var(--color-danger-dark)}.plan-feedback-input-wrapper{border:1px solid var(--color-gray-300);border-radius:.375rem;flex:1;align-items:center;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.plan-feedback-input-wrapper:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 2px #3b82c426}.plan-feedback-input{font-size:var(--font-size-sm);border:none;outline:none;flex:1;min-width:0;padding:.375rem .5rem;font-family:inherit}.plan-feedback-input::placeholder{color:var(--color-text-tertiary)}.plan-feedback-send{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.375rem;transition:color .15s;display:flex}.plan-feedback-send:hover:not(:disabled){color:var(--color-primary-500)}.plan-feedback-send:disabled{opacity:.3;cursor:not-allowed}.right-panel{background:var(--color-background);border-left:none;flex-direction:column;height:100%;display:flex}.right-panel.empty{justify-content:center;align-items:center}.empty-state{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm);padding:1.5rem}.chat-header{border-bottom:1px solid var(--color-border);background:var(--color-background);justify-content:space-between;align-items:center;padding:1rem;display:flex}.chat-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.chat-header-actions{align-items:center;gap:.375rem;display:flex}.btn-plan-mode{border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);background:var(--color-background);color:var(--color-text-secondary);cursor:pointer;border-radius:.375rem;align-items:center;gap:.375rem;padding:.375rem .75rem;transition:all .15s;display:flex}.btn-plan-mode:hover{background:var(--color-primary-50);border-color:var(--color-primary-300);color:var(--color-primary-600)}.btn-plan-mode.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-600)}.plan-mode-banner{background:var(--color-primary-50);border-bottom:1px solid var(--color-primary-200);font-size:var(--font-size-xs);color:var(--color-primary-700);text-align:center;padding:.375rem 1rem}.btn-clear{border:1px solid var(--color-gray-300);font-size:var(--font-size-sm);background:var(--color-background);color:var(--color-danger-dark);cursor:pointer;border-radius:.375rem;align-items:center;gap:.375rem;padding:.375rem .75rem;transition:all .15s;display:flex}.btn-clear:hover:not(:disabled){background:var(--color-danger-light);border-color:var(--color-danger-light)}.btn-clear:disabled{opacity:.5;cursor:not-allowed}.chat-error{background:var(--color-danger-light);border-bottom:1px solid var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.btn-dismiss-error{width:1.5rem;height:1.5rem;color:var(--color-danger-dark);font-size:var(--font-size-xl);cursor:pointer;background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;transition:background .15s;display:flex}.btn-dismiss-error:hover{background:#dc26261a}.chat-recovering{background:var(--color-primary-50);border-bottom-color:var(--color-primary-200);color:var(--color-primary-700);animation:2s ease-in-out infinite recoveryPulse}@keyframes recoveryPulse{0%,to{opacity:1}50%{opacity:.7}}.chat-messages{background:var(--color-surface);flex:1;padding:1rem;overflow-y:auto}.no-messages{height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-sm);text-align:center;justify-content:center;align-items:center;padding:2rem;display:flex}.message{background:var(--color-background);border:1px solid var(--color-border);border-radius:.5rem;margin-bottom:1rem;padding:.75rem}.message.user{background:var(--color-primary-100);border-color:var(--color-primary-200);margin-left:2rem}.message.assistant{background:var(--color-background);border-color:var(--color-border);margin-right:2rem}.message.assistant.thinking{background:var(--color-gray-100);border-color:var(--color-gray-300)}.message-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.message-role{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);align-items:center;gap:.375rem;display:flex}.role-icon{color:var(--color-text-secondary)}.message-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.message-content{font-size:var(--font-size-sm);line-height:var(--line-height-normal);color:var(--color-text-primary)}.message-content p{margin:0}.message-content h1,.message-content h2,.message-content h3{font-weight:var(--font-weight-semibold);margin:.75rem 0 .5rem}.message-content h1{font-size:var(--font-size-xl)}.message-content h2{font-size:var(--font-size-lg)}.message-content h3{font-size:var(--font-size-base)}.message-content code{font-family:var(--font-family-mono);font-size:var(--font-size-sm);background:#0000000d;border-radius:.25rem;padding:.125rem .375rem}.message-content pre{background:var(--color-gray-800);color:var(--color-gray-100);border-radius:.375rem;margin:.5rem 0;padding:.75rem;overflow-x:auto}.message-content pre code{color:inherit;background:0 0;padding:0}.message-content ul{margin:.5rem 0;padding-left:1.5rem;list-style-type:disc;list-style-position:outside}.message-content ol{margin:.5rem 0;padding-left:1.5rem;list-style-type:decimal;list-style-position:outside}.message-content li{margin:.25rem 0;padding-left:.25rem}.message-content ul ul{margin:.25rem 0;list-style-type:circle}.message-content ul ul ul{list-style-type:square}.message-content ol ol{margin:.25rem 0;list-style-type:lower-alpha}.message-content ol ol ol{list-style-type:lower-roman}.thinking-indicator{align-items:center;gap:.5rem;padding:.5rem 0;display:flex}.dot{background:var(--color-text-secondary);border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite dotMove}.dot-1{animation-delay:0s}.dot-2{animation-delay:.2s}.dot-3{animation-delay:.4s}@keyframes dotMove{0%,to{opacity:.4;transform:translate(0)}10%{opacity:.7;transform:translate(3px,-5px)}20%{opacity:1;transform:translate(-2px,4px)}30%{opacity:.8;transform:translate(5px,2px)}40%{opacity:.6;transform:translate(-3px,-3px)}50%{opacity:.9;transform:translate(2px,5px)}60%{opacity:.7;transform:translate(-4px,-2px)}70%{opacity:.5;transform:translate(4px,3px)}80%{opacity:.8;transform:translate(-1px,-4px)}90%{opacity:.6;transform:translate(2px,1px)}}.tool-indicators{flex-direction:column;gap:.25rem;margin-top:.5rem;display:flex}.tool-indicator{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-snug);align-items:center;gap:.5rem;display:flex}.tool-indicator-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.tool-indicator-dot.running{background:var(--color-primary-500);animation:1s ease-in-out infinite toolDotBlink}.tool-indicator-dot.done{background:var(--color-success)}.tool-indicator-dot.error{background:var(--color-danger)}@keyframes toolDotBlink{0%,to{opacity:1}50%{opacity:.3}}.tool-indicator-label{white-space:nowrap}.todo-widget{border-top:1px solid var(--color-border);background:var(--color-surface);max-height:200px;padding:.5rem 1rem;overflow-y:auto}.todo-header{justify-content:space-between;align-items:center;margin-bottom:.375rem;display:flex}.todo-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.todo-progress{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium)}.todo-list{flex-direction:column;gap:.125rem;display:flex}.todo-item{font-size:var(--font-size-sm);line-height:var(--line-height-snug);align-items:flex-start;gap:.375rem;padding:.1875rem 0;display:flex}.todo-checkbox{color:var(--color-text-tertiary);font-size:var(--font-size-sm);line-height:var(--line-height-snug);flex-shrink:0}.todo-checkbox.checked{color:var(--color-success)}.todo-text{color:var(--color-gray-700);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.todo-text.done{color:var(--color-text-tertiary);text-decoration:line-through}.todo-item.in-progress .todo-checkbox{color:var(--color-primary-500);animation:1s ease-in-out infinite todoBlink}@keyframes todoBlink{0%,to{opacity:1}50%{opacity:.3}}.todo-animate-add{animation:.3s ease-out todoSlideIn}@keyframes todoSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.todo-animate-done .todo-checkbox{animation:.4s ease-out todoCheckPop}@keyframes todoCheckPop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.chat-input-container{border-top:1px solid var(--color-border);background:var(--color-background);padding:1rem}.chat-offline-notice{font-size:var(--font-size-xs);color:var(--color-warning-dark);background-color:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:6px;align-items:center;gap:6px;margin-bottom:8px;padding:6px 10px;display:flex}.chat-input{border:1px solid var(--color-gray-300);width:100%;font-size:var(--font-size-sm);resize:vertical;border-radius:.375rem;min-height:60px;max-height:150px;margin-bottom:.5rem;padding:.75rem;font-family:inherit}.chat-input:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus);outline:none}.chat-input:disabled{background:var(--color-gray-100);cursor:not-allowed}.btn-send{background:var(--color-primary-500);width:100%;color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:.375rem;justify-content:center;align-items:center;gap:.375rem;padding:.625rem;transition:background .15s;display:flex}.btn-send:hover:not(:disabled){background:var(--color-primary-600)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.image-suggestion-modal-overlay{z-index:9999;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.image-suggestion-modal{background:var(--color-background);box-shadow:var(--shadow-xl);border-radius:.5rem;flex-direction:column;width:100%;max-width:500px;max-height:90vh;display:flex;overflow:hidden}.image-suggestion-header{border-bottom:1px solid var(--color-border);padding:1.5rem}.image-suggestion-header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.image-suggestion-body{padding:1.5rem;overflow-y:auto}.image-suggestion-text{font-size:var(--font-size-base);color:var(--color-gray-700);line-height:var(--line-height-normal);margin:0 0 1.5rem}.image-suggestion-details{flex-direction:column;gap:1rem;display:flex}.detail-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.375rem;padding:.75rem}.detail-item strong{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:.5rem;display:block}.prompt-preview,.reason-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal);margin:0}.image-suggestion-footer{border-top:1px solid var(--color-border);background:var(--color-surface);gap:.75rem;padding:1.5rem;display:flex}.image-suggestion-footer .btn-secondary,.image-suggestion-footer .btn-primary{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;border:none;border-radius:.375rem;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.625rem 1rem;transition:all .15s;display:flex}.image-suggestion-footer .btn-secondary{background:var(--color-background);color:var(--color-gray-700);border:1px solid var(--color-gray-300)}.image-suggestion-footer .btn-secondary:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-text-tertiary)}.image-suggestion-footer .btn-primary{background:var(--color-primary-500);color:var(--color-text-inverse)}.image-suggestion-footer .btn-primary:hover:not(:disabled){background:var(--color-primary-600)}.image-suggestion-footer button:disabled{opacity:.6;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:var(--color-text-inverse);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite spin}.continuation-prompt{background:var(--color-warning-light);border:1px solid var(--color-warning);font-size:var(--font-size-sm);color:var(--color-warning-dark);border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.5rem .75rem;display:flex}.btn-continue{background:var(--color-warning);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap;border:none;border-radius:4px;padding:.35rem .75rem}.btn-continue:hover:not(:disabled){background:var(--color-warning-dark)}.btn-continue:disabled{opacity:.5;cursor:not-allowed}.phase-overview-grid>.phase-overview-card:last-child:nth-child(odd){grid-column:1/-1}.phase-overview-title-group{align-items:baseline;gap:.5rem;display:flex}.page-type-count-badge{color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;display:inline-flex}.page-type-header-actions{align-items:center;gap:.5rem;display:flex}.page-type-overview-add{border-top:1px solid var(--color-border-light);margin-top:.75rem;padding-top:.75rem}.activity-meta{align-items:center;gap:8px;display:flex}.activity-page-link{font-size:var(--font-size-xs);color:var(--color-primary-500);cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.activity-page-link:hover{color:var(--color-primary-700)}.project-summary-card{border:1px solid var(--color-border);background:var(--color-background);border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000000a}.project-summary-header{justify-content:space-between;align-items:center;margin-bottom:.75rem;display:flex}.project-summary-header .phase-overview-card-title{margin:0}.project-summary-regenerate{border:1px solid var(--color-border);background:var(--color-background);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;border-radius:.375rem;justify-content:center;align-items:center;transition:all .15s;display:flex}.project-summary-regenerate:hover{background:var(--color-surface);color:var(--color-text-primary)}.project-summary-regenerate:disabled{opacity:.5;cursor:not-allowed}.project-summary-regenerate .spinning{animation:1s linear infinite spin}.project-summary-error{background:var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm);border-radius:.375rem;margin-bottom:.5rem;padding:.5rem .75rem}.project-summary-skeleton{flex-direction:column;gap:.5rem;display:flex}.skeleton-line{background:var(--color-border);border-radius:4px;height:14px;animation:1.5s ease-in-out infinite pulse}.project-summary-content{font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:var(--line-height-relaxed);position:relative}.project-summary-content.clamped{-webkit-line-clamp:12;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.project-summary-content.clamped:after{content:"";background:linear-gradient(transparent, var(--color-background));pointer-events:none;height:2.5rem;position:absolute;bottom:0;left:0;right:0}.project-summary-toggle{width:100%;color:var(--color-primary-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center;background:0 0;border:none;margin-top:.25rem;padding:.375rem;display:block}.project-summary-toggle:hover{color:var(--color-primary-600);background:var(--color-surface);border-radius:.25rem}.project-summary-content p{margin:0 0 .75rem}.project-summary-content p:last-child{margin-bottom:0}.project-summary-content ul{margin:.25rem 0 .75rem;padding-left:1.25rem}.project-summary-content li{margin-bottom:.25rem}.project-summary-content strong{color:var(--color-text-primary)}.project-phase-progress-list{flex-direction:column;gap:.75rem;display:flex}.project-phase-progress-row{flex-direction:column;gap:.25rem;display:flex}.project-phase-progress-header{justify-content:space-between;align-items:baseline;display:flex}.project-phase-progress-name{font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.project-phase-progress-pct{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);flex-shrink:0}.project-phase-state-chips{flex-wrap:wrap;gap:.25rem;margin-top:.125rem;display:flex}.project-phase-state-chips .phase-state-chip{padding:1px 6px;font-size:10px}.project-phase-empty{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic}.project-action-items{flex-direction:column;gap:0;display:flex}.project-action-item{border-bottom:1px solid var(--color-gray-100);border-radius:.25rem;align-items:flex-start;gap:.625rem;padding:.5rem .625rem;display:flex}.project-action-item:last-child{border-bottom:none}.project-action-icon{flex-shrink:0;margin-top:.125rem}.project-action-item.priority-critical .project-action-icon,.project-action-item.priority-high .project-action-icon{color:var(--color-danger-dark)}.project-action-item.priority-medium .project-action-icon{color:var(--color-warning-dark)}.project-action-item.priority-low .project-action-icon{color:var(--color-text-tertiary)}.project-action-item.priority-info .project-action-icon{color:var(--color-primary-500)}.project-action-content{flex:1;min-width:0}.project-action-page-link{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-600);cursor:pointer}.project-action-page-link:hover{text-decoration:underline}.project-action-reasons{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.125rem;display:block}.project-phase-col{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:160px;overflow:hidden}.project-health-score-card{margin-bottom:1rem}.project-health-score-layout{grid-template-columns:1fr 1fr;align-items:center;gap:1rem;display:grid}.project-health-score-gauge{flex-direction:column;justify-content:center;align-items:center;display:flex}.project-health-score-gauge .project-score-gauge{width:100%}.project-health-score-radar{min-width:0}@media (width<=700px){.project-health-score-layout{grid-template-columns:1fr}}.project-health-score-subtitle{text-align:center;color:var(--color-text-tertiary);margin:.25rem 0 0;font-size:11px}.project-score-gauge{margin:0 auto}.project-score-gauge-label{text-align:center;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:-.25rem;margin-bottom:.5rem;display:block}.project-criteria-radar{margin-top:.25rem}.state-dist{flex-direction:column;gap:.625rem;display:flex}.state-dist-bar{border:1px solid #0000000a;border-radius:6px;height:28px;display:flex;overflow:hidden;box-shadow:inset 0 1px 2px #0000000f}.state-dist-segment{cursor:default;justify-content:center;align-items:center;transition:opacity .15s,transform .15s;display:flex;position:relative}.state-dist-segment.hovered{opacity:1;box-shadow:inset 0 0 0 1px #ffffff4d}.state-dist-segment.dimmed{opacity:.45}.state-dist-segment-label{color:#ffffffe6;text-shadow:0 1px 2px #0003;pointer-events:none;font-size:11px;font-weight:600}.state-dist-float-tooltip{white-space:nowrap;background:var(--color-gray-800);color:var(--color-text-inverse);pointer-events:none;z-index:var(--z-index-tooltip);border-radius:4px;padding:.25rem .5rem;font-size:11px;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 2px 8px #00000026}.state-dist-float-tooltip strong{font-weight:var(--font-weight-semibold)}.state-dist-legend{flex-wrap:wrap;justify-content:center;gap:.375rem;display:flex}.state-dist-chip{border-radius:var(--border-radius-full);border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-secondary);cursor:default;align-items:center;gap:.3rem;padding:.2rem .5rem;font-size:11px;line-height:1;transition:all .15s;display:inline-flex}.state-dist-chip:hover,.state-dist-chip.active{background:var(--color-surface);border-color:var(--color-border-dark);color:var(--color-text-primary)}.state-dist-chip-dot{border-radius:var(--border-radius-full);flex-shrink:0;width:7px;height:7px}.state-dist-chip-label{font-weight:var(--font-weight-medium)}.state-dist-chip-count{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-left:.1rem}.main-content:has(.workspace-container){min-height:0;overflow:hidden}.workspace-container{flex-direction:column;height:calc(100vh - 65px);display:flex;overflow:hidden}.workspace-panels{flex:1;overflow:hidden}.workspace-panel{background:var(--color-background);overflow:hidden}.workspace-panel-middle{container:middle-panel/inline-size}.workspace-resize-handle{background:var(--color-border);cursor:col-resize;width:1px;transition:background .2s}.workspace-resize-handle:hover{background:var(--color-text-tertiary);width:3px}.workspace-loading,.workspace-error{height:calc(100vh - 64px);font-size:var(--font-size-lg);color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.workspace-error{color:var(--color-danger-dark)}.breadcrumbs{align-items:center;display:flex}.breadcrumbs-list{align-items:center;gap:var(--spacing-2);flex-wrap:wrap;margin:0;padding:0;list-style:none;display:flex}.breadcrumb-item{align-items:center;gap:var(--spacing-2);display:flex}.breadcrumb-link{align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-base);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm);text-decoration:none;display:flex}.breadcrumb-link:hover{color:var(--color-primary-500);background-color:var(--color-surface-hover)}.breadcrumb-separator{color:var(--color-text-tertiary);flex-shrink:0}.breadcrumb-current{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium);padding:var(--spacing-1) var(--spacing-2)}@media (width<=640px){.breadcrumbs-list{font-size:var(--font-size-xs)}.breadcrumb-link span{display:none}.breadcrumb-link:first-child span{display:inline}}.card{background-color:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card-hoverable:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-clickable{cursor:pointer}.card-padding-none{padding:0}.card-padding-sm{padding:var(--spacing-4)}.card-padding-md{padding:var(--spacing-6)}.card-padding-lg{padding:var(--spacing-8)}.card-header{padding-bottom:var(--spacing-4);border-bottom:var(--border-width) solid var(--color-border);margin-bottom:var(--spacing-4);font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg)}.card-padding-none .card-header{padding:var(--spacing-6);padding-bottom:var(--spacing-4);margin-bottom:0}.card-body{flex:1}.card-footer{padding-top:var(--spacing-4);border-top:var(--border-width) solid var(--color-border);margin-top:var(--spacing-4)}.card-padding-none .card-footer{padding:var(--spacing-6);padding-top:var(--spacing-4);margin-top:0}.page-editor-page{padding:var(--spacing-8);max-width:var(--container-xl);width:100%;margin:0 auto;overflow-x:hidden}.editor-header{gap:var(--spacing-4);margin-bottom:var(--spacing-6);flex-direction:column;display:flex}.editor-header-content{align-items:center;gap:var(--spacing-4);display:flex}.editor-icon{border-radius:var(--border-radius-lg);background:linear-gradient(135deg, var(--color-primary-500) 0%, var(--color-primary-600) 100%);width:48px;height:48px;color:var(--color-text-inverse);flex-shrink:0;justify-content:center;align-items:center;display:flex}.editor-actions{align-items:center;gap:var(--spacing-3);display:flex}.editor-card{min-height:600px;overflow:hidden}.editor-card .cm-editor{border:none;border-radius:0;height:100%;min-height:600px}.editor-card .cm-content{font-family:var(--font-family-mono);font-size:var(--font-size-sm)}@media (width<=768px){.page-editor-page{padding:var(--spacing-4)}.editor-header{gap:var(--spacing-3)}.editor-header-content{flex-direction:column;align-items:stretch}.editor-icon{width:40px;height:40px}.editor-actions{flex-direction:column;width:100%}.editor-actions>*{width:100%}.editor-card{min-height:400px}.editor-card :global(.CodeMirror){min-height:400px}}.badge{font-weight:var(--font-weight-medium);border-radius:var(--border-radius-full);white-space:nowrap;justify-content:center;align-items:center;display:inline-flex}.badge-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.badge-md{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm)}.badge-lg{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-base)}.badge-success{background-color:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning-dark)}.badge-danger{background-color:var(--color-danger-light);color:var(--color-danger-dark)}.badge-info{background-color:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background-color:var(--color-gray-100);color:var(--color-gray-700)}.page-view-page{padding:var(--spacing-8);max-width:var(--container-lg);width:100%;margin:0 auto;overflow-x:hidden}.page-view-actions{align-items:center;gap:var(--spacing-3);display:flex}.page-view-content{gap:var(--spacing-6);flex-direction:column;display:flex}.page-metadata{background:linear-gradient(135deg, var(--color-primary-50) 0%, var(--color-background) 100%)}.metadata-grid{gap:var(--spacing-6);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.metadata-item{align-items:flex-start;gap:var(--spacing-3);display:flex}.metadata-icon{color:var(--color-text-secondary);flex-shrink:0;margin-top:2px}.metadata-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-1);display:block}.metadata-value{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium);display:block}.page-content-card{min-height:400px}.page-view-page .page-content{max-width:800px}@media (width<=768px){.page-view-page{padding:var(--spacing-4)}.metadata-grid{gap:var(--spacing-4);grid-template-columns:1fr}.page-view-actions{width:100%}.page-view-actions>*{flex:1}}.table-wrapper{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);min-width:100%}.table thead{background-color:var(--color-surface)}.table th{padding:var(--spacing-4);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border-bottom:var(--border-width) solid var(--color-border);text-align:left;white-space:nowrap}.table td{padding:var(--spacing-4);color:var(--color-text-primary);border-bottom:var(--border-width) solid var(--color-border-light)}.table tbody tr:last-child td{border-bottom:none}.table-striped tbody tr:nth-child(2n){background-color:var(--color-surface)}.table-hoverable tbody tr{transition:background-color var(--transition-fast)}.table-hoverable tbody tr:hover{background-color:var(--color-surface-hover)}.table-loading{padding:var(--spacing-12);justify-content:center;align-items:center;gap:var(--spacing-4);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);flex-direction:column;display:flex}.table-loading-spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary-500);border-radius:50%;width:32px;height:32px;animation:1s linear infinite spin}.table-loading p{color:var(--color-text-secondary);margin:0}.table-empty{padding:var(--spacing-12);text-align:center;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg)}@media (width<=768px){.table th,.table td{padding:var(--spacing-3)}.table{font-size:var(--font-size-xs)}.table th{white-space:nowrap}.table td{text-overflow:ellipsis;max-width:200px;overflow:hidden}}@media (width<=640px){.table-wrapper{border-radius:var(--border-radius-md)}.table th,.table td{padding:var(--spacing-2)}.table{font-size:var(--font-size-xs)}.table-actions button{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-2xs)}}.empty-state{padding:var(--spacing-12) var(--spacing-6);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{width:80px;height:80px;margin-bottom:var(--spacing-4);color:var(--color-text-tertiary);background-color:var(--color-surface);border-radius:var(--border-radius-full);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0}.empty-state-description{font-size:var(--font-size-base);color:var(--color-text-secondary);max-width:500px;margin:0 0 var(--spacing-6) 0;line-height:var(--line-height-relaxed)}.empty-state-action{margin-top:var(--spacing-2)}.recharts-responsive-container svg{max-width:none}.settings-page{padding:var(--spacing-8);max-width:var(--container-xl);width:100%;margin:0 auto;overflow-x:hidden}.settings-tabs{gap:var(--spacing-2);margin-bottom:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border);display:flex;overflow-x:auto}.settings-tab{align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;display:flex}.settings-tab:hover{color:var(--color-primary-600);background-color:var(--color-surface-hover);border-radius:var(--border-radius-md) var(--border-radius-md) 0 0}.settings-tab.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.tab-header{margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border);justify-content:space-between;align-items:flex-start;display:flex}.tab-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0}.tab-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.table-actions{align-items:center;gap:var(--spacing-2);display:flex}.settings-table-wrapper{position:relative}.settings-table-wrapper .table th:last-child{padding-left:var(--spacing-6);background:0 0;border-left:none}.table-actions-cell{vertical-align:middle;width:100px;padding-left:var(--spacing-6)!important;background:0 0!important;border-bottom:none!important;border-left:none!important}.settings-table-wrapper .table td:nth-last-child(2),.settings-table-wrapper .table th:nth-last-child(2){border-right:none}.row-actions-container{align-items:center;gap:var(--spacing-2);opacity:.6;transition:opacity var(--transition-base);justify-content:flex-end;display:flex}.row-actions-container:hover,.table tbody tr:hover .row-actions-container{opacity:1}@media (width<=768px){.settings-table-wrapper .table th:last-child{padding-left:var(--spacing-3)}.table-actions-cell{width:auto;padding-left:var(--spacing-3)!important}.row-actions-container{opacity:1;justify-content:center}}.table-type-icon{vertical-align:middle;margin-right:var(--spacing-2);color:var(--color-text-secondary);display:inline-flex}.draggable-cell{align-items:center;gap:var(--spacing-2);display:flex}.drag-handle{opacity:.3;transition:opacity var(--transition-base);flex-shrink:0}.draggable-cell>span{flex:1}.settings-table-wrapper tr[draggable=true]{cursor:move}.settings-table-wrapper tr[draggable=true]:hover .drag-handle{opacity:.6}.settings-table-wrapper tr.dragging-row{opacity:.5;background-color:var(--color-primary-50)!important}.settings-table-wrapper tr.drag-over-row{border-top:3px solid var(--color-primary-500)}@media (width<=768px){.settings-table-wrapper tr[draggable=true]{cursor:default}.drag-handle{display:none}}.form-fields{gap:var(--spacing-6);flex-direction:column;display:flex}.form-group{gap:var(--spacing-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group label.form-checkbox-label{align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;-webkit-user-select:none;user-select:none;display:flex}.form-checkbox-label input[type=checkbox]{cursor:pointer;width:16px;min-width:16px;height:16px;accent-color:var(--color-primary-500);flex-shrink:0;margin:0}.form-checkbox-label span{font-weight:var(--font-weight-normal);line-height:var(--line-height-none)}.form-help-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.form-select{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);transition:all var(--transition-base);cursor:pointer;outline:none}.form-select:hover{border-color:var(--color-border-dark)}.form-select:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.form-textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);font-family:var(--font-family-mono);color:var(--color-text-primary);background-color:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);resize:vertical;transition:all var(--transition-base);line-height:var(--line-height-relaxed);outline:none}.form-textarea:hover{border-color:var(--color-border-dark)}.form-textarea:focus{border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.checkbox-list{gap:var(--spacing-1);padding:var(--spacing-3);background-color:var(--color-surface);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);flex-direction:column;display:flex}.checkbox-item{align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm);cursor:pointer;transition:background-color var(--transition-fast);-webkit-user-select:none;user-select:none;display:flex}.checkbox-item:hover{background-color:var(--color-surface-hover)}.checkbox-item input[type=checkbox]{cursor:pointer;width:16px;min-width:16px;height:16px;accent-color:var(--color-primary-500);flex-shrink:0;margin:0}.checkbox-item span{font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-primary);line-height:var(--line-height-normal);flex:1}@media (width<=768px){.settings-page{padding:var(--spacing-4)}.settings-tabs{-webkit-overflow-scrolling:touch;gap:0}.settings-tab{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs);flex:1;justify-content:center}.settings-tab span{display:none}.tab-header{gap:var(--spacing-4);flex-direction:column}.tab-title{font-size:var(--font-size-xl)}.table-actions{align-items:stretch;gap:var(--spacing-2);flex-direction:column}.table-actions>*{width:100%}.table-actions button{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}}@media (width<=640px){.settings-page{padding:var(--spacing-3)}.tab-header{margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4)}.tab-title{font-size:var(--font-size-lg)}.tab-description{font-size:var(--font-size-xs)}}.intg-grid{gap:var(--spacing-2);flex-direction:column;display:flex}.intg-row{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);transition:border-color .15s}.intg-row:hover,.intg-row--expanded{border-color:var(--color-border-dark,#9ca3af)}.intg-row-main{padding:var(--spacing-3) var(--spacing-4);justify-content:space-between;align-items:center;display:flex}.intg-row-left{align-items:center;gap:var(--spacing-3);display:flex}.intg-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.intg-account{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.intg-row-right{align-items:center;gap:var(--spacing-2);display:flex}.intg-status{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.intg-status--connected{color:var(--color-success-dark,#16a34a);align-items:center;gap:4px;display:inline-flex}.intg-status--unavailable{color:var(--color-text-tertiary)}.intg-details{padding:var(--spacing-3) var(--spacing-4);border-top:var(--border-width) solid var(--color-border-light,#f3f4f6);justify-content:space-between;align-items:center;display:flex}.intg-capabilities{align-items:center;gap:var(--spacing-2);flex-wrap:wrap;display:flex}.intg-cap-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-right:var(--spacing-3)}.intg-details-actions{gap:var(--spacing-2);flex-shrink:0;display:flex}.integration-direction-badge{font-size:var(--font-size-xs);white-space:nowrap;border-radius:3px;flex-shrink:0;align-items:center;padding:1px 6px;font-weight:600;display:inline-flex}.integration-direction-badge.context{color:#3b82f6;background:#3b82f61a;border:1px solid #3b82f6}.integration-avatar{border-radius:50%;width:24px;height:24px}.not-found-page{justify-content:center;align-items:center;min-height:calc(100vh - 64px);display:flex}.not-found-content{text-align:center;padding:var(--spacing-8)}.not-found-code{font-size:80px;font-weight:var(--font-weight-bold);color:var(--color-primary-200);line-height:var(--line-height-none);margin-bottom:var(--spacing-4);display:block}.not-found-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.not-found-message{color:var(--color-text-secondary);margin-bottom:var(--spacing-6)}.App{background-color:var(--color-surface);flex-direction:column;width:100%;max-width:100vw;min-height:100vh;display:flex;overflow-x:hidden}.main-content{flex:1;width:100%;max-width:100%;min-height:calc(100vh - 64px);overflow-x:hidden}.main-content-full{min-height:100vh}.loading-screen{justify-content:center;align-items:center;gap:var(--spacing-4);flex-direction:column;min-height:50vh;display:flex}.loading-screen p{color:var(--color-text-secondary);font-size:var(--font-size-base)}.markdown-viewer{line-height:var(--line-height-relaxed);color:var(--color-text-primary)}.markdown-viewer h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin-top:var(--spacing-8);margin-bottom:var(--spacing-4);color:var(--color-text-primary);line-height:var(--line-height-tight)}.markdown-viewer h1:first-child{margin-top:0}.markdown-viewer h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-6);margin-bottom:var(--spacing-3);color:var(--color-text-primary);line-height:var(--line-height-tight)}.markdown-viewer h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-6);margin-bottom:var(--spacing-3);color:var(--color-text-primary);line-height:var(--line-height-tight)}.markdown-viewer h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-4);margin-bottom:var(--spacing-2);color:var(--color-text-primary)}.markdown-viewer p{margin-bottom:var(--spacing-4);color:var(--color-text-primary)}.markdown-viewer a{color:var(--color-primary-600);border-bottom:1px solid var(--color-primary-300);transition:all var(--transition-base);text-decoration:none}.markdown-viewer a:hover{color:var(--color-primary-700);border-bottom-color:var(--color-primary-600)}.markdown-viewer code{background-color:var(--color-gray-100);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm);font-family:var(--font-family-mono);color:var(--color-danger-dark);font-size:.9em}.markdown-viewer pre{background-color:var(--color-gray-900);color:var(--color-gray-100);padding:var(--spacing-4);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-4);border:var(--border-width) solid var(--color-border);overflow-x:auto}.markdown-viewer pre code{color:inherit;font-size:var(--font-size-sm);background-color:#0000;padding:0}.markdown-viewer ul,.markdown-viewer ol{margin-left:var(--spacing-6);margin-bottom:var(--spacing-4)}.markdown-viewer li{margin-bottom:var(--spacing-2)}.markdown-viewer blockquote{border-left:4px solid var(--color-primary-500);padding-left:var(--spacing-4);margin-left:0;margin-bottom:var(--spacing-4);color:var(--color-text-secondary);font-style:italic}.markdown-viewer table{border-collapse:collapse;width:100%;margin-bottom:var(--spacing-4);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);overflow:hidden}.markdown-viewer th{background-color:var(--color-surface);padding:var(--spacing-3);text-align:left;font-weight:var(--font-weight-semibold);border-bottom:var(--border-width) solid var(--color-border)}.markdown-viewer td{padding:var(--spacing-3);border-bottom:var(--border-width) solid var(--color-border-light)}.markdown-viewer tr:last-child td{border-bottom:none}.markdown-viewer hr{border:none;border-top:var(--border-width) solid var(--color-border);margin:var(--spacing-8) 0}.markdown-viewer img{border-radius:var(--border-radius-md);max-width:100%;height:auto;margin:var(--spacing-4) 0}
