: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: #ffffff;--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: #ffffff;--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 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--shadow-focus: 0 0 0 3px rgba(59, 130, 196, .15);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .06);--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{height:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;width:100%;max-width:100vw}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);overflow-x:hidden;width:100%}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}button{background:none;border:none;cursor:pointer}a{text-decoration:none;color:inherit}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!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{min-height:100vh;isolation:isolate;overflow-x:hidden;width:100%;max-width:100vw}.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{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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%;margin-left:auto;margin-right:auto;padding-left:var(--spacing-4);padding-right:var(--spacing-4)}@media(min-width:640px){.container{max-width:var(--container-sm)}}@media(min-width:768px){.container{max-width:var(--container-md)}}@media(min-width:1024px){.container{max-width:var(--container-lg)}}@media(min-width:1280px){.container{max-width:var(--container-xl)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}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:transparent;padding:0}.toast-container{position:fixed;z-index:var(--z-index-toast);display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);pointer-events:none}.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{display:flex;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)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.toast-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.toast-message{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.toast-close{display:flex;align-items:center;justify-content:center;padding:var(--spacing-1);border-radius:var(--border-radius-sm);color:var(--color-text-secondary);transition:all var(--transition-base);background:none;border:none;cursor:pointer;flex-shrink:0}.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(max-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);position:sticky;top:0;z-index:var(--z-index-sticky);width:100%;max-width:100vw;overflow-x:hidden}.navbar-container{margin:0;padding:0 var(--spacing-6);display:flex;align-items:center;justify-content:space-between;height:64px;width:100%}.navbar-brand a{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-decoration:none;transition:color var(--transition-base);letter-spacing:var(--letter-spacing-tight)}.navbar-brand a:hover{color:var(--color-text-primary)}.navbar-brand img{height:28px;width:auto}.navbar-mobile-toggle{display:none;padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-primary);background:none;border:none;cursor:pointer;transition:background-color var(--transition-base)}.navbar-mobile-toggle:hover{background-color:var(--color-surface-hover)}.navbar-menu{display:flex;align-items:center;gap:var(--spacing-8);flex:1;justify-content:space-between;margin-left:var(--spacing-8)}.navbar-links{display:flex;align-items:center;gap:var(--spacing-2)}.navbar-link{display:flex;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);text-decoration:none;transition:all var(--transition-base);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:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background-color:var(--color-primary-600)}.navbar-user-section{display:flex;align-items:center;gap:var(--spacing-3);position:relative}.navbar-user{display:flex;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)}.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{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--border-radius-full);background-color:var(--color-primary-100);color:var(--color-primary-600);flex-shrink:0}.navbar-user-avatar-img{width:24px;height:24px;border-radius:50%;object-fit:cover;display:block}.navbar-user-info{display:flex;flex-direction:column;line-height:var(--line-height-tight)}.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);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-user-chevron{color:var(--color-text-tertiary);transition:transform .2s ease;flex-shrink:0}.navbar-user-chevron--open{transform:rotate(180deg)}.navbar-logout{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-secondary);background:none;border:none;cursor:pointer;transition:all var(--transition-base)}.navbar-logout:hover{color:var(--color-danger);background-color:var(--color-danger-light)}.navbar-credits-badge{display:flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-warning-dark);background-color:var(--color-warning-light);border-radius:9999px;border:1px solid var(--color-warning);text-decoration:none;cursor:pointer;transition:opacity var(--transition-base)}.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{display:flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-warning-dark);background-color:var(--color-warning-light);border-radius:9999px;border:1px solid var(--color-warning)}.tenant-dropdown-backdrop{position:fixed;inset:0;z-index:998}.tenant-dropdown-menu{position:fixed;min-width:240px;background:var(--color-background);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-lg);border:var(--border-width) solid var(--color-border);z-index:999;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);border-left:3px solid transparent;transition:background var(--transition-base)}.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{display:flex;gap:var(--spacing-2);align-items:center}.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{height:1px;background-color:var(--color-border);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(max-width:768px){.navbar-container{padding:0 var(--spacing-4);height:56px}.navbar-mobile-toggle{display:flex}.navbar-menu{position:fixed;inset:56px 0 0;background-color:var(--color-background);flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;margin-left:0;padding:var(--spacing-4);transform:translate(100%);transition:transform var(--transition-base);overflow-y:auto}.navbar-menu-open{transform:translate(0);box-shadow:var(--shadow-lg)}.navbar-links{flex-direction:column;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)}.navbar-link{padding:var(--spacing-3) var(--spacing-4);justify-content:flex-start}.navbar-link-active:after{display:none}.navbar-user-section{flex-direction:column;align-items:stretch;gap:var(--spacing-3)}.navbar-user,.navbar-logout{justify-content:flex-start}}.btn{display:inline-flex;align-items:center;justify-content: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}.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);transform:translateY(-1px);box-shadow:var(--shadow-md)}.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);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.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);transform:translateY(-1px);box-shadow:var(--shadow-md)}.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);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger:active:not(:disabled){background-color:var(--color-danger-dark);transform:translateY(0)}.btn-ghost{background-color:transparent;color:var(--color-text-primary)}.btn-ghost:hover:not(:disabled){background-color:var(--color-surface-hover)}.btn-ghost:active:not(:disabled){background-color:var(--color-gray-200)}.btn-link{background-color:transparent;color:var(--color-primary-500);padding:0;min-height:auto;height:auto}.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{display:inline-flex;align-items:center;justify-content:center}.btn-icon-loading{animation:spin 1s linear infinite}.btn-content{display:inline-flex;align-items:center}.btn:not(:has(.btn-content)){padding:var(--spacing-2);min-width:auto;aspect-ratio:1}.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{display:flex;flex-direction:column;gap:var(--spacing-2)}.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{position:relative;display:flex;align-items:center}.input{width:100%;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);background-color:var(--color-background);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{position:absolute;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);pointer-events:none}.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{flex:1;display:flex;align-items:center;justify-content:center;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);position:relative;overflow:hidden}.login-brand-panel:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(255,255,255,.06) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,255,255,.04) 0%,transparent 50%);pointer-events:none}.login-brand-content{position:relative;max-width:480px;width:100%}.login-brand-logo{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-10)}.login-brand-logo img{height:44px;width:auto}.login-mobile-logo img{height:36px;width:auto}.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{display:flex;flex-direction:column;gap:var(--spacing-5)}.login-brand-feature{display:flex;align-items:flex-start;gap:var(--spacing-4)}.login-brand-feature>svg{flex-shrink:0;margin-top:2px;color:#ffffffb3}.login-brand-feature div{display:flex;flex-direction:column;gap:2px}.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{flex:1;display:flex;align-items:center;justify-content:center;background:var(--color-background);padding:var(--spacing-12) var(--spacing-8)}.login-form-container{width:100%;max-width:400px}.login-mobile-logo{display:none;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-6)}.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{display:flex;flex-direction:column;gap:var(--spacing-5)}.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{display:flex;align-items:center;margin:var(--spacing-5) 0;color:var(--color-text-tertiary)}.login-divider-line{flex:1;border-bottom:1px solid var(--color-border)}.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{display:flex;align-items:center;width:100%;padding:0;border:1px solid var(--color-border);border-radius:var(--border-radius-md);background:var(--color-background);cursor:pointer;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);height:44px;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{display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0}.google-sign-in-text{flex:1;text-align:center;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);text-decoration:none;transition:color var(--transition-fast)}.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(max-width:960px){.login-brand-panel{display:none}.login-form-panel{flex:1}.login-mobile-logo{display:flex}}@media(max-width:640px){.login-form-panel{padding:var(--spacing-6) var(--spacing-4)}.login-form-title{font-size:var(--font-size-xl)}}.tenant-selector-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-background) 100%);padding:var(--spacing-6)}.tenant-selector-container{width:100%;max-width:520px}.tenant-selector-header{text-align:center;margin-bottom:var(--spacing-8)}.tenant-selector-logo{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:var(--border-radius-xl);background:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-600) 100%);color:var(--color-text-inverse);margin-bottom:var(--spacing-4);box-shadow:var(--shadow-lg)}.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{display:flex;flex-direction:column;gap:var(--spacing-3)}.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;transition:all .2s ease;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between}.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{display:flex;gap:var(--spacing-2);align-items:center}.tenant-selector-badge{display:inline-block;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}.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{background-color:transparent;color:var(--color-text-tertiary)}.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(max-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%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:var(--border-radius-sm)}@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);overflow:hidden;margin-bottom:var(--spacing-4)}.skeleton-card-image{width:100%;height:200px;background:linear-gradient(90deg,var(--color-gray-200) 0%,var(--color-gray-100) 50%,var(--color-gray-200) 100%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}.skeleton-card-content{padding:var(--spacing-6);display:flex;flex-direction:column;gap:var(--spacing-3)}.skeleton-table{border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3)}.skeleton-table-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-4)}.skeleton-table-row .skeleton-text{margin-bottom:0}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:var(--spacing-2)}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:none;border:2px solid var(--color-border);border-radius:var(--border-radius-md);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-base)}.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, rgba(99, 102, 241, .08));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, rgba(99, 102, 241, .12))}.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);display:flex;flex-direction:column;gap:var(--spacing-4);height:100%}.project-card:hover{border-color:var(--color-border-dark);box-shadow:0 4px 16px #0000000f;transform:translateY(-2px)}.project-card-top{display:flex;justify-content:space-between;align-items:flex-start}.project-card-top-right{display:flex;align-items:flex-start;gap:var(--spacing-1)}.project-card-type-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;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)}.project-card-score-ring{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-card-score-value{position:absolute;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-info{display:flex;flex-direction:column;gap:4px;flex:1;min-height:0}.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);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-progress{display:flex;flex-direction:column;gap:6px}.project-card-progress-header{display:flex;justify-content:space-between;align-items:center}.project-card-progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.project-card-progress-right{display:flex;align-items:center;gap:6px}.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{position:relative;width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-card-score-value-sm{position:absolute;font-size:8px;font-weight:var(--font-weight-bold);top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-progress-bar{height:4px;background:var(--color-gray-100);border-radius:2px;overflow:hidden}.project-card-progress-fill{height:100%;border-radius:2px;transition:width var(--transition-slow)}.project-card-progress-secondary{font-size:11px;color:var(--color-text-tertiary)}.project-card-gauge{position:relative;width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.project-card-gauge-value{position:absolute;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);top:50%;left:50%;transform:translate(-50%,-50%)}.project-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:var(--spacing-4);border-top:var(--border-width) solid var(--color-border-light)}.project-card-footer-right{display:flex;align-items:center;gap:.375rem}.project-card-action-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 6px;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);line-height:1}.project-card-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary);display:flex;align-items:center;gap:4px}.project-card-phase{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-gray-100);padding:2px 8px;border-radius:var(--border-radius-sm);font-weight:var(--font-weight-medium);max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-card-menu{position:relative}.project-card-menu-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--color-text-tertiary);border-radius:var(--border-radius-md);cursor:pointer;opacity:0;transition:all var(--transition-base)}.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{position:absolute;top:100%;right:0;z-index:50;min-width:160px;padding:4px;background:var(--color-background);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);box-shadow:0 4px 16px #0000001a,0 1px 4px #0000000f;margin-top:4px}.project-card-dropdown-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:8px 12px;border:none;background:none;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)}.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{display:flex;flex-direction:column;height:100%;background:var(--color-background);overflow-y:auto}.phase-overview-scroll{flex:1 0 auto;overflow:visible;padding:1.5rem}.phase-overview-header{margin-bottom:1.5rem}.phase-overview-header-top{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.25rem}.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);margin:0;line-height:var(--line-height-normal)}.phase-overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}@media(max-width:700px){.phase-overview-grid{grid-template-columns:1fr}}.phase-overview-card{border:1px solid var(--color-border);border-radius:.5rem;padding:1rem;background:var(--color-background);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{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.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{display:flex;flex-direction:column;gap:.5rem}.phase-criteria-item{display:flex;align-items:center;gap:.5rem}.phase-criteria-name{font-size:var(--font-size-sm);color:var(--color-gray-700);width:160px;min-width:160px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phase-criteria-bar-track{flex:1;height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.phase-criteria-bar-fill{height:100%;border-radius:4px;transition:width .3s ease}.phase-criteria-score{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);min-width:28px;text-align:right}.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{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.375rem}.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{height:10px;background:var(--color-border);border-radius:5px;overflow:hidden;display:flex}.phase-progress-segment{height:100%;flex:none;transition:width .3s ease}.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{height:100%;background:var(--color-primary-500);border-radius:5px;transition:width .3s ease}.phase-checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.375rem}.phase-checklist-item{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-gray-700)}.phase-checklist-icon{font-size:var(--font-size-sm);width:1rem;text-align:center;flex-shrink:0}.phase-checklist-icon.met{color:var(--color-success-dark)}.phase-checklist-icon.unmet{color:var(--color-danger-dark)}.phase-state-distribution{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.75rem}.phase-state-chip{display:inline-flex;align-items:center;gap:.25rem;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:999px}.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{position:relative;display:inline-flex;align-items:center}.phase-progress-info{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;font-size:var(--font-size-2xs);color:var(--color-text-tertiary);margin-left:.25rem;cursor:pointer}.phase-progress-tooltip{position:absolute;top:calc(100% + 6px);left:0;z-index:50;width:280px;padding:.625rem .75rem;background:var(--color-gray-800);color:var(--color-gray-100);border-radius:.375rem;font-size:var(--font-size-xs);line-height:var(--line-height-normal);box-shadow:0 4px 12px #00000026;pointer-events:none}.phase-progress-tooltip ul{margin:.25rem 0;padding-left:1.25rem}.phase-progress-tooltip li{margin:0}.phase-missing-pages{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.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{display:flex;flex-wrap:wrap;gap:.375rem}.phase-missing-btn{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;font-size:var(--font-size-xs);border:1px solid var(--color-gray-300);border-radius:.25rem;background:var(--color-background);color:var(--color-gray-700);cursor:pointer;transition:all .15s ease}.phase-missing-btn:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary)}.phase-blockers{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.phase-blockers-header{display:flex;align-items:center;gap:.375rem;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-danger-dark);margin-bottom:.5rem}.phase-blockers-list{display:flex;flex-direction:column;gap:.375rem}.phase-blocker-item{display:flex;flex-direction:column;gap:.125rem;padding:.375rem .5rem;background:var(--color-danger-light);border-radius:.25rem}.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{display:block;width:100%;padding:.375rem;margin-top:.25rem;border:none;background:none;color:var(--color-primary-500);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center}.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{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.phase-page-table th{text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);padding:.5rem .75rem;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}.phase-page-table th:hover{color:var(--color-gray-700)}.phase-page-table th .sort-indicator{margin-left:.25rem;font-size:var(--font-size-2xs)}.phase-page-table td{padding:.5rem .75rem;border-bottom:1px solid var(--color-gray-100);color:var(--color-gray-700)}.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{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:999px}.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{width:28px;min-width:28px;padding:.5rem .25rem .5rem .75rem;text-align:center;cursor:default}.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{display:inline-flex;align-items:center;gap:3px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary)}.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{display:inline-block;vertical-align:middle}.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;padding:1.5rem;color:var(--color-text-tertiary);font-style:italic;font-size:var(--font-size-sm)}.phase-insights-list{display:flex;flex-direction:column;gap:0}.phase-insight-item{padding:.625rem 0;border-bottom:1px solid var(--color-gray-100)}.phase-insight-item:last-child{border-bottom:none}.phase-insight-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.25rem}.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);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.phase-insight-reasoning.expanded{display:block;-webkit-line-clamp:unset}.phase-insight-expand{border:none;background:none;color:var(--color-primary-500);font-size:var(--font-size-xs);cursor:pointer;padding:0;margin-top:.125rem}.phase-insight-expand:hover{color:var(--color-primary-600)}.phase-insights-empty{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:var(--color-success-light);border:1px solid var(--color-success-light);border-radius:.375rem;font-size:var(--font-size-sm);color:var(--color-success-dark)}.phase-activity-list{display:flex;flex-direction:column;gap:0}.phase-activity-item{display:flex;align-items:flex-start;gap:.75rem;padding:.625rem 0;border-bottom:1px solid var(--color-gray-100)}.phase-activity-item:last-child{border-bottom:none}.phase-activity-dot{width:8px;height:8px;border-radius:50%;background:var(--color-primary-500);margin-top:.375rem;flex-shrink:0}.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);font-style:italic;margin-top:.25rem}.phase-activity-empty{text-align:center;padding:1rem;color:var(--color-text-tertiary);font-size:var(--font-size-sm);font-style:italic}.phase-activity-toggle{display:block;width:100%;padding:.5rem;margin-top:.25rem;border:none;background:none;color:var(--color-primary-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center}.phase-activity-toggle:hover{color:var(--color-primary-600);background:var(--color-surface);border-radius:.25rem}.phase-overview-loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.phase-overview-error{padding:1rem;background:var(--color-danger-light);border:1px solid var(--color-danger-light);border-radius:.375rem;color:var(--color-danger-dark);font-size:var(--font-size-sm);margin-bottom:1rem}.onboarding{max-width:640px;margin:0 auto;text-align:center;padding:var(--spacing-12) 0}.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);display:flex;align-items:center;justify-content:center;border:var(--border-width) solid var(--color-primary-200);color:var(--color-primary-500)}.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{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-4);margin-bottom:var(--spacing-10)}.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{width:32px;height:32px;border-radius:var(--border-radius-lg);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-3)}.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);padding:12px 28px;border-radius:var(--border-radius-lg);box-shadow:0 2px 8px #0000001f}.onboarding-cta:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0000002e}@media(max-width:768px){.onboarding{padding:var(--spacing-8) var(--spacing-4)}.onboarding-steps{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.modal-content{background:var(--color-background);border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:90%;max-height:90vh;display:flex;flex-direction:column;animation:slideIn .15s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-close-btn{background:none;border:none;font-size:var(--font-size-2xl);color:var(--color-text-secondary);cursor:pointer;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:all .15s}.modal-close-btn:hover{background:var(--color-gray-100);color:var(--color-text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:.75rem}.modal-btn{padding:.5rem 1rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;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{width:100%;padding:.5rem .75rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);box-sizing:border-box}.modal-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.modal-textarea{width:100%;min-height:80px;padding:.5rem .75rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);resize:vertical;box-sizing:border-box;font-family:inherit}.modal-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-index-modal-backdrop);padding:var(--spacing-4);animation:fadeIn var(--transition-fast)}.modal{background-color:var(--color-background);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-2xl);display:flex;flex-direction:column;max-height:90vh;z-index:var(--z-index-modal);animation:slideUp var(--transition-base);width:100%}@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{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border)}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2);border-radius:var(--border-radius-md);color:var(--color-text-secondary);transition:all var(--transition-base);background:none;border:none;cursor:pointer}.modal-close:hover{background-color:var(--color-surface-hover);color:var(--color-text-primary)}.modal-body{flex:1;overflow-y:auto;padding:var(--spacing-6)}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-3);padding:var(--spacing-6);border-top:var(--border-width) solid var(--color-border)}.modal-body .checkbox-list{max-height:none;overflow-y:visible}.modal-body .checkbox-item{display:flex;align-items:center;gap:var(--spacing-2)}@media(max-width:640px){.modal-overlay{padding:var(--spacing-2)}.modal{max-height:95vh}.modal-header,.modal-body,.modal-footer{padding:var(--spacing-4)}}.textarea-container{display:flex;flex-direction:column;gap:var(--spacing-2)}.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{width:100%;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);background-color:var(--color-background);color:var(--color-text-primary);transition:all var(--transition-base);outline:none;resize:vertical;font-family:inherit;line-height:var(--line-height-relaxed)}.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{display:flex;flex-direction:column;gap:var(--spacing-2)}.psm-repo-item{display:flex;align-items:center;gap:var(--spacing-2);padding:8px 12px;background:var(--color-gray-50);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md)}.psm-repo-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.psm-repo-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-gray-100);padding:2px 8px;border-radius:var(--border-radius-full)}.psm-repo-remove{background:none;border:none;color:var(--color-text-tertiary);cursor:pointer;font-size:var(--font-size-lg);width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius-sm);transition:all var(--transition-base)}.psm-repo-remove:hover:not(:disabled){background:var(--color-danger-light);color:var(--color-danger)}.psm-add-repo{display:flex;gap:var(--spacing-2);align-items:center}.psm-add-repo-select{flex:1}.psm-add-repo-label{width:140px;flex:0 0 auto}.psm-input,.psm-select{width:100%;padding:8px 12px;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-md);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)}.psm-input:focus,.psm-select:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.psm-input:disabled,.psm-select:disabled{background:var(--color-gray-50);cursor:not-allowed}.psm-select{cursor:pointer}.psm-footer{display:flex;align-items:center;justify-content:flex-end;width:100%}.psm-footer-right{display:flex;gap:var(--spacing-2)}.project-form-page{max-width:720px;margin:0 auto;padding:var(--spacing-8)}.project-form{display:flex;flex-direction:column;gap:var(--spacing-6)}.form-label .required{color:var(--color-danger);margin-left:var(--spacing-1)}.form-select{width:100%;padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);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);outline:none;cursor:pointer}.form-help-text a{color:var(--color-primary-500);text-decoration:none}.form-help-text a:hover{text-decoration:underline}.type-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-3);margin-top:var(--spacing-1)}.type-card{display:flex;flex-direction:column;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}.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, rgba(99, 102, 241, .08));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, rgba(99, 102, 241, .12))}.type-card-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.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{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-3) var(--spacing-4);background:none;border:none;cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-base)}.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, rgba(99, 102, 241, .1));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{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-4);background-color:var(--color-surface);border-radius:var(--border-radius-md);max-height:400px;overflow-y:auto}.checkbox-item{display:flex;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)}.checkbox-item input[type=checkbox]{width:18px;height:18px;margin-top:2px;cursor:pointer;accent-color:var(--color-primary-500);flex-shrink:0}.checkbox-content{display:flex;flex-direction:column;gap:var(--spacing-1);flex:1}.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{display:flex;justify-content:flex-end;gap:var(--spacing-3);padding-top:var(--spacing-4);border-top:var(--border-width) solid var(--color-border)}@media(max-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(max-width:480px){.type-cards-grid{grid-template-columns:1fr}}.project-list-page{padding:var(--spacing-8);max-width:var(--container-xl);margin:0 auto;width:100%;overflow-x:hidden}.project-list-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-6)}.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{display:flex;gap:var(--spacing-3);align-items:center;flex-shrink:0}.project-list-search{position:relative}.project-list-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.project-list-search-input{width:240px;padding:8px 12px 8px 36px;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-background);outline:none;transition:all var(--transition-base);font-family:var(--font-family-sans)}.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{display:flex;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)}.project-list-stat{display:flex;align-items:center;gap:var(--spacing-2)}.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{width:1px;background:var(--color-border);align-self:stretch}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--spacing-4)}.project-card-link{display:block;text-decoration:none;color:inherit;height:100%}.project-list-no-results{grid-column:1 / -1;text-align:center;padding:var(--spacing-12) 0;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}@media(max-width:1024px){.projects-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media(max-width:768px){.project-list-page{padding:var(--spacing-4)}.project-list-header{flex-direction:column;gap:var(--spacing-4)}.project-list-header-right{width:100%}.project-list-search{flex:1}.project-list-search-input{width:100%}.projects-grid{grid-template-columns:1fr;gap:var(--spacing-4)}.project-list-stats{flex-wrap:wrap;gap:var(--spacing-4)}.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{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-6);width:100%}.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);margin:0;line-height:var(--line-height-relaxed);max-width:700px}.page-header-actions{display:flex;align-items:center;gap:var(--spacing-3);flex-shrink:0}@media(max-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:spin 1s linear infinite}.spinner-primary{color:var(--color-primary-500)}.spinner-white{color:var(--color-text-inverse)}.spinner-current{color:currentColor}.score-badge-container{position:relative;display:inline-flex;align-items:center}.score-badge{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:28px;padding:0 8px;border-radius:14px;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}.score-badge.compact{min-width:28px;height:20px;padding:0 5px;font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);border-radius:10px;line-height:20px;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center}.score-dot{display:inline-block;width:8px;height:8px;border-radius:50%;cursor:pointer;flex-shrink:0}.score-dot.processing{background-color:var(--color-text-secondary)!important;animation:pulse 2s infinite}.score-badge.processing{background-color:var(--color-text-secondary);animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.score-badge.polling{position:relative}.polling-indicator{position:absolute;top:2px;right:2px;width:6px;height:6px;background-color:var(--color-background);border-radius:50%;animation:pulse-dot 1.5s ease-in-out infinite}.score-badge.compact .polling-indicator{width:4px;height:4px;top:1px;right:1px}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.8)}}.score-tooltip{position:fixed;padding:16px;background:var(--color-background);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 10px 25px #00000026;width:400px;max-width:90vw;z-index:10000;max-height:calc(100vh - var(--tooltip-top, 100px) - 20px);overflow-y:auto;overflow-x:hidden}.tooltip-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.score-tooltip h4{margin:0;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold)}.tooltip-close{background:none;border:none;font-size:var(--font-size-2xl);line-height:var(--line-height-none);color:var(--color-text-secondary);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.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{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.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);padding:2px 6px;border-radius:4px;color:var(--color-text-inverse)}.criterion-reasoning{margin:0;font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:var(--line-height-snug)}.left-panel{display:flex;flex-direction:column;height:100%;background:var(--color-surface);border-right:none}.phases-container{flex:1;overflow-y:auto;overflow-x:hidden}.project-overview-nav-item{display:flex;align-items:center;padding:6px 1rem;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);cursor:pointer;border-radius:.375rem;transition:all .15s;-webkit-user-select:none;user-select:none;position:relative}.project-menu-container{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.btn-project-menu{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:.375rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;flex-shrink:0;line-height:var(--line-height-none)}.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{display:flex;align-items:center;min-height:32px;padding:6px 1rem;font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);gap:.5rem;border-radius:.375rem;cursor:pointer;transition:all .15s}.phase-header:hover{background:var(--color-border)}.phase-header-content{display:flex;align-items:center;flex:1;-webkit-user-select:none;user-select:none;gap:.5rem}.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);display:flex;align-items:center;justify-content:center;flex-shrink:0;height:20px;width:20px}.phase-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:20px;line-height:var(--line-height-none);display:inline-flex;align-items:center}.pages-list{padding-left:0}.no-pages{padding:.75rem 1rem;font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.page-item{display:flex;align-items:center;justify-content:space-between;min-height:32px;padding:6px 1rem;padding-right:10px;border-radius:.375rem;cursor:pointer;transition:all .15s;position:relative;gap:.5rem;line-height:var(--line-height-none);padding-left:calc(2rem + 14px)}.page-type-group .page-item{padding-left:4.625rem;padding-top:6px;padding-bottom:6px}.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{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem;overflow:hidden;line-height:var(--line-height-none)}.page-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:0 1 auto;min-width:0;height:20px;line-height:var(--line-height-none);display:inline-flex;align-items:center}.state-badge{display:inline-flex;align-items:center;padding:2px 8px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:.25rem;flex:0 20 auto;min-width:0;overflow:hidden;white-space:nowrap;height:20px}.lock-icon{display:inline-flex;align-items:center;color:var(--color-text-secondary);flex:0 20 auto;min-width:0;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{display:flex;align-items:center;justify-content:space-between;min-height:32px;padding:6px 1rem 6px calc(2rem + 14px);padding-right:10px;font-size:var(--font-size-sm);color:var(--color-gray-600);font-weight:var(--font-weight-medium);gap:.5rem;line-height:var(--line-height-none);border-radius:.375rem;cursor:pointer;transition:all .15s}.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{display:flex;align-items:center;flex:1;min-width:0;overflow:hidden;-webkit-user-select:none;user-select:none;gap:.5rem;line-height:var(--line-height-none)}.doc-type-name{flex:0 1 auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;height:20px;line-height:var(--line-height-none);display:inline-flex;align-items:center}.btn-add-doc{position:relative;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:.25rem;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-light);line-height:var(--line-height-none);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;cursor:pointer;transition:all .15s;flex-shrink:0}.btn-add-doc:before{content:"+";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);margin-top:-1px}.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:transparent}.page-menu-container{position:absolute;right:10px;top:50%;transform:translateY(-50%);display:flex;align-items:center}.btn-page-menu{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:.25rem;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;visibility:hidden;flex-shrink:0;line-height:var(--line-height-none)}.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);border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:9999;min-width:120px;overflow:hidden}.menu-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:.5rem .75rem;background:var(--color-background);border:none;text-align:left;font-size:var(--font-size-sm);color:var(--color-gray-700);cursor:pointer;transition:background .15s}.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{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:var(--color-background);border-radius:.5rem;padding:1.5rem;min-width:400px;max-width:500px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal-content h3{margin:0 0 1rem;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.modal-body{margin-bottom:1.5rem}.modal-body label{display:block;margin-bottom:.5rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-gray-700)}.modal-body input{width:100%;padding:.625rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);font-family:inherit;box-sizing:border-box}.modal-body input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.modal-body p{margin:0 0 .75rem;font-size:var(--font-size-sm);color:var(--color-gray-700)}.modal-body p:last-child{margin-bottom:0}.warning-text{color:var(--color-danger-dark);font-weight:var(--font-weight-medium)}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end}.btn-cancel,.btn-create,.btn-delete{padding:.5rem 1rem;border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s}.btn-cancel{background:var(--color-background);border:1px solid var(--color-gray-300);color:var(--color-gray-700)}.btn-cancel:hover{background:var(--color-surface)}.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{display:inline-flex;align-items:center;color:var(--color-primary-500);margin-left:4px;flex-shrink:0}.agent-indicator.agent-active{animation:agent-pulse 1.5s ease-in-out infinite}.agent-indicator.agent-error{color:var(--color-primary-700);opacity:.6}.version-history-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.version-history-modal{background:var(--color-background);border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;width:90%;max-width:1200px;max-height:85vh;display:flex;flex-direction:column}.version-history-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border)}.version-history-header h3{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.version-history-loading,.version-history-error{padding:2rem;text-align:center}.version-history-error{color:var(--color-danger)}.version-history-content{flex:1;display:grid;grid-template-columns:350px 1fr;overflow:hidden}.version-list{border-right:1px solid var(--color-border);overflow-y:auto;padding:1.5rem}.version-list h4{margin:0 0 1rem;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)}.no-versions{color:var(--color-text-tertiary);font-size:var(--font-size-sm);font-style:italic}.version-item{padding:1rem;margin-bottom:.75rem;border:1px solid var(--color-border);border-radius:.375rem;cursor:pointer;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{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.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);margin-bottom:.25rem;font-weight:var(--font-weight-medium)}.version-comment{margin:.5rem 0 0;font-size:var(--font-size-sm);color:var(--color-gray-700);line-height:var(--line-height-snug)}.btn-restore{margin-top:.75rem;padding:.375rem .75rem;background:var(--color-primary-500);color:#fff;border:none;border-radius:.25rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s}.btn-restore:hover{background:var(--color-primary-600)}.version-preview{overflow-y:auto;padding:1.5rem}.preview-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.preview-header>div:first-child{flex:1}.preview-header h4{margin:0 0 .25rem;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.preview-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:block}.view-mode-toggle{display:flex;gap:.5rem;border:1px solid var(--color-border);border-radius:.375rem;padding:.25rem;background:var(--color-gray-50)}.toggle-btn{padding:.5rem 1rem;background:transparent;border:none;border-radius:.25rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;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{margin-bottom:1rem;padding:.75rem;background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:.375rem;font-size:var(--font-size-sm);color:var(--color-warning-dark)}.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);margin:1.5rem 0 1rem;color:var(--color-text-primary)}.preview-content h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin:1.25rem 0 .75rem;color:var(--color-text-primary)}.preview-content h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:1rem 0 .5rem;color:var(--color-text-primary)}.preview-content code{background:var(--color-gray-100);padding:.125rem .375rem;border-radius:.25rem;font-family:var(--font-family-mono);font-size:.875em}.preview-content pre{background:var(--color-gray-800);color:var(--color-gray-100);padding:1rem;border-radius:.375rem;overflow-x:auto;margin:1rem 0}.preview-content pre code{background:transparent;padding:0;color:inherit}.no-content{color:var(--color-text-tertiary);font-style:italic;text-align:center;padding:2rem}.no-selection{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-base)}.version-history-actions{display:flex;justify-content:flex-end;padding:1.5rem;border-top:1px solid var(--color-border)}.btn-close-modal{padding:.625rem 1.25rem;border:1px solid var(--color-gray-300);background:var(--color-background);color:var(--color-gray-700);border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;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{padding:.75rem;background:var(--color-gray-100);border:1px solid var(--color-gray-300);border-radius:.375rem;margin-bottom:1rem;font-size:var(--font-size-sm);color:var(--color-gray-700)}.diff-loading,.no-changes{color:var(--color-text-tertiary);font-style:italic;text-align:center;padding:2rem;font-family:var(--font-family-sans)}.diff-content{background:var(--color-gray-50);border:1px solid var(--color-border);border-radius:.375rem;overflow-x:auto;max-height:600px;overflow-y:auto}.diff-line{padding:.25rem .75rem;white-space:pre-wrap;word-break:break-all;line-height:var(--line-height-normal);border-left:3px solid transparent}.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{display:flex;flex-wrap:wrap;gap:.25rem;padding:.5rem;background:var(--color-surface);border-bottom:1px solid var(--color-border);align-items:center}.toolbar-btn{width:1.75rem;height:1.75rem;padding:0;border:1px solid var(--color-gray-300);border-radius:.25rem;background:var(--color-background);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all .15s}.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)}.toolbar-separator{width:1px;height:1.5rem;background:var(--color-gray-300);margin:0 .25rem}.codemirror-editor-container{height:100%;width:100%;overflow:hidden}.codemirror-editor-container .cm-editor{height:100%}.cm-ai-highlight{background-color:#fb923c33;border-radius:2px;animation:ai-highlight-fade 5s ease-out forwards}@keyframes ai-highlight-fade{0%{background-color:#fb923c33}70%{background-color:#fb923c33}to{background-color:transparent}}.file-browser-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.file-browser-modal{background:var(--color-background);border-radius:.5rem;box-shadow:var(--shadow-xl);width:90%;max-width:1000px;height:80vh;display:flex;flex-direction:column;animation:slideIn .2s ease-out}.file-browser-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.file-browser-header h3{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.file-browser-content{flex:1;display:grid;grid-template-columns:1fr 1fr;overflow:hidden}.file-list-section{border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.file-list-header{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.file-list-header h4{margin:0;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)}.file-list{flex:1;overflow-y:auto;padding:.5rem}.file-list-loading,.file-list-empty{padding:2rem;text-align:center;color:var(--color-text-tertiary)}.file-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-radius:.375rem;cursor:pointer;transition:all .15s;border:2px solid transparent}.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;overflow:hidden;text-overflow:ellipsis}.file-list-item-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.125rem}.file-list-item-actions{display:flex;gap:.25rem;opacity:0;transition:opacity .15s}.file-list-item:hover .file-list-item-actions{opacity:1}.file-action-btn{padding:.25rem .5rem;border:1px solid var(--color-gray-300);border-radius:.25rem;background:var(--color-background);color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center}.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{display:flex;flex-direction:column;overflow:hidden}.file-preview-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.file-preview-header h4{margin:0;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)}.preview-actions{display:flex;gap:.5rem}.btn-preview-action{padding:.375rem .75rem;border:1px solid var(--color-gray-300);border-radius:.25rem;background:var(--color-background);color:var(--color-gray-700);font-size:var(--font-size-sm);cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:.375rem}.btn-preview-action:hover{background:var(--color-gray-100);border-color:var(--color-text-tertiary)}.file-preview-content{flex:1;overflow:auto;padding:1.5rem;display:flex;align-items:center;justify-content:center}.no-preview{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);width:100%;height:100%}.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);margin:.5rem 0;word-break:break-word}.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{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-preview img{max-width:100%;max-height:100%;object-fit:contain;border-radius:.375rem;box-shadow:var(--shadow-md)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.manage-context-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.manage-context-modal{background:var(--color-background);border-radius:.5rem;box-shadow:var(--shadow-xl);width:90%;max-width:1000px;height:80vh;display:flex;flex-direction:column;animation:slideIn .2s ease-out;overflow:hidden}.manage-context-header{display:flex;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);gap:1.5rem;flex-shrink:0}.manage-context-header h3{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);white-space:nowrap}.manage-context-tabs{display:flex;gap:0;flex:1}.manage-context-tab{padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;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{background:none;border:none;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;border-radius:.25rem;display:flex;align-items:center;justify-content:center;margin-left:auto}.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{position:static;background:none;height:100%;animation:none}.manage-context-files-wrapper .file-browser-modal{width:100%;max-width:none;height:100%;border-radius:0;box-shadow:none;animation:none}.manage-context-files-wrapper .file-browser-header{display:none}.manage-context-sources{display:grid;grid-template-columns:1fr 1fr;height:100%;overflow:hidden}.manage-context-sources-list{border-right:1px solid var(--color-border);display:flex;flex-direction:column;overflow:hidden}.manage-context-search{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);flex-shrink:0}.manage-context-search-input{width:100%;padding:.5rem .75rem;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:.375rem;outline:none;box-sizing:border-box;background:var(--color-background);color:var(--color-text-primary)}.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;overflow-y:auto;padding:.5rem}.manage-context-section{margin-bottom:.5rem}.manage-context-section-label{display:flex;align-items:center;gap:.375rem;padding:.375rem .5rem;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)}.manage-context-source-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:.375rem;cursor:pointer;transition:all .15s;border:2px solid transparent}.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{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.manage-context-delete-btn{background:none;border:none;cursor:pointer;color:var(--color-text-tertiary);padding:.125rem;flex-shrink:0;opacity:0;transition:opacity .15s;display:flex;align-items:center}.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);padding:.125rem .5rem;border:1px solid var(--color-primary-500);border-radius:.25rem;background:none;color:var(--color-primary-500);cursor:pointer;font-weight:var(--font-weight-medium);flex-shrink:0;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);padding:1px 4px;border-radius:3px;background:var(--color-surface);color:var(--color-text-secondary);flex-shrink:0}.manage-context-url-hint{padding:.75rem 1rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.manage-context-url-hint strong{color:var(--color-text-primary)}.manage-context-empty{padding:1.5rem;text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.manage-context-sources-preview{display:flex;flex-direction:column;overflow:hidden}.manage-context-preview-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.manage-context-preview-content{padding:1.5rem;overflow-y:auto}.manage-context-preview-title{margin:0 0 1.5rem;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);word-break:break-word}.manage-context-preview-field{margin-bottom:1rem}.manage-context-preview-label{display:block;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}.manage-context-preview-url{font-size:var(--font-size-sm);color:var(--color-primary-500);text-decoration:none;display:inline-flex;align-items:center;gap:.25rem;word-break:break-all}.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{padding:16px;background:var(--color-surface);border-top:1px solid var(--color-border);container-type:inline-size;container-name:comments-panel;height:100%;overflow-y:auto;box-sizing:border-box}.comments-section{margin-bottom:24px}.comments-section-title{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:12px;padding:8px 0}.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{display:flex;flex-direction:column;gap:12px}.comment-item{background:var(--color-background);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease;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{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:var(--font-size-xs)}.comment-author{font-weight:var(--font-weight-semibold);color:var(--color-gray-800);display:flex;align-items:center;gap:4px}.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);padding:6px 10px;margin:8px 0;font-size:var(--font-size-sm);color:var(--color-warning-dark);border-radius:4px;font-style:italic}.comment-text{color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:var(--line-height-normal);margin:8px 0;word-wrap:break-word}.comment-actions{display:flex;gap:8px;margin-top:12px;padding-top:8px;border-top:1px solid var(--color-border)}.btn-comment-action{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border:none;border-radius:6px;cursor:pointer;transition:all .2s;background:transparent}.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-radius:8px;padding:12px;margin-top:12px;border:1px solid var(--color-border)}.reply-textarea{width:100%;padding:10px;border:1px solid var(--color-gray-300);border-radius:6px;font-size:var(--font-size-sm);font-family:inherit;resize:vertical;min-height:60px;margin-bottom:8px;transition:border-color .2s}.reply-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.reply-form-actions{display:flex;justify-content:flex-end;gap:8px}.btn-reply-cancel,.btn-reply-submit{padding:6px 12px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:6px;cursor:pointer;transition:all .2s;border:none;display:flex;align-items:center;gap:4px}.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{margin-top:8px;padding-left:16px;border-left:2px solid var(--color-border)}.resolved-section .comments-section-title{color:var(--color-text-secondary)}@container (max-width: 350px){.btn-comment-action .btn-text{display:none}.btn-comment-action{padding:6px 8px;min-width:32px;justify-content:center}}@supports not (container-type: inline-size){@media(max-width:350px){.btn-comment-action .btn-text{display:none}.btn-comment-action{padding:6px 8px;min-width:32px;justify-content:center}}}@media(max-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{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000}.comment-form{position:absolute;background:var(--color-background);border-radius:8px;box-shadow:0 10px 25px #0003;width:400px;max-width:90vw;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;transform:translate(-50%,-50%)}.comment-form-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.comment-form-title{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700)}.comment-form-close{width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:4px;transition:all .2s}.comment-form-close:hover{background:var(--color-border);color:var(--color-text-primary)}.comment-form-selected-text{padding:.75rem 1rem;background:var(--color-primary-50);border-left:3px solid var(--color-primary-500);font-size:var(--font-size-sm);font-style:italic;color:var(--color-primary-800);margin:1rem;border-radius:4px}.comment-form form{padding:0 1rem 1rem;display:flex;flex-direction:column;gap:.75rem}.comment-form-textarea{width:100%;padding:.75rem;border:1px solid var(--color-gray-300);border-radius:6px;font-size:var(--font-size-sm);font-family:inherit;resize:vertical;min-height:80px;transition:all .2s}.comment-form-textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.comment-form-actions{display:flex;justify-content:flex-end;gap:.5rem}.btn-cancel,.btn-submit{padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border:none;border-radius:6px;cursor:pointer;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{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:.25rem 1rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--color-border);width:100%;box-sizing:border-box;flex-shrink:0}.panel-header.sticky-header{position:sticky;top:0;z-index:10;background:var(--color-background);will-change:transform}.panel-header .page-title-section{min-width:0;flex:1 1 auto}.panel-header .page-title-section h2{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.title-with-state{display:flex;align-items:center;gap:1rem;margin-bottom:.25rem;min-width:0}.state-select{padding:.375rem .625rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);background:var(--color-background);cursor:pointer;flex-shrink:0}.state-select:disabled{background:var(--color-gray-100);cursor:not-allowed}.page-metadata{display:flex;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.page-actions{display:flex;flex-direction:row-reverse;gap:.5rem;align-items:center;flex-wrap:wrap;flex-shrink:0;justify-content:flex-start;margin-left:auto}.page-actions-group{display:flex;gap:.5rem;align-items:center}.panel-actions-divider{width:1px;height:18px;background:var(--color-border);margin:0 var(--spacing-1)}@container middle-panel (max-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 (max-width: 450px){.panel-header .page-title-section{flex:1 1 100%}}@container middle-panel (max-width: 400px){.page-metadata{display:none}}@supports not (container-type: inline-size){@media(max-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(max-width:768px){.panel-header .page-title-section{flex:1 1 100%}}@media(max-width:640px){.page-metadata{display:none}}}.agent-activity-panel{border-top:1px solid var(--color-border);background:var(--color-primary-50);display:flex;flex-direction:column;flex-shrink:0;position:sticky;bottom:0;z-index:5}.agent-activity-panel.expanded{flex-shrink:0;overflow:hidden}.agent-resize-handle{height:6px;cursor:row-resize;display:flex;align-items:center;justify-content:center;background:var(--color-primary-50);border-bottom:1px solid var(--color-border);flex-shrink:0}.agent-resize-handle:hover{background:var(--color-primary-100)}.agent-resize-grip{width:32px;height:2px;border-radius:1px;background:var(--color-primary-300)}.agent-resize-handle:hover .agent-resize-grip{background:var(--color-primary-500)}.agent-activity-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--color-primary-50);border-bottom:1px solid var(--color-border);flex-shrink:0}.agent-activity-header:hover{background:var(--color-primary-100)}.agent-activity-title{display:flex;align-items:center;gap:6px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-500)}.activity-count{background:var(--color-primary-500);color:var(--color-text-inverse);border-radius:10px;padding:0 6px;font-size:var(--font-size-xs);line-height:18px}.agent-activity-list{overflow-y:auto;flex:1;padding:4px 0}.activity-loading,.activity-empty{padding:12px;text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.activity-item{display:flex;align-items:flex-start;gap:8px;padding:6px 12px;font-size:var(--font-size-sm);border-bottom:1px solid var(--color-primary-100)}.activity-item:last-child{border-bottom:none}.activity-icon{flex-shrink:0;margin-top:2px;color:var(--color-primary-500)}.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{display:flex;flex-direction:column;gap:2px;min-width:0}.activity-summary{color:var(--color-gray-700);line-height:var(--line-height-snug);word-break:break-word;cursor:pointer}.activity-summary.clamped{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;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{display:flex;align-items:center;gap:8px}.agent-token-usage{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary-400)}.middle-panel{display:flex;flex-direction:column;height:100%;width:100%;background:var(--color-background);min-width:0;overflow:hidden;container-type:inline-size;container-name:middle-panel}.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{position:sticky;top:0;z-index:10;background:var(--color-background);will-change:transform}.empty-state{text-align:center;color:var(--color-text-tertiary);font-size:var(--font-size-lg)}.page-title-section h2.editable-title{cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background .15s}.page-title-section h2.editable-title:hover{background:var(--color-gray-100)}.page-title-section .title-input{margin:0;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;padding:.25rem .5rem;font-family:inherit;outline:none;width:auto;min-width:200px}.version-link{cursor:pointer;color:var(--color-primary-500);transition:all .15s;display:inline-flex;align-items:center;gap:.25rem}.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{position:relative;display:inline-flex;align-items:center;color:var(--color-danger-dark);cursor:pointer}.lock-tooltip{visibility:hidden;position:absolute;top:calc(100% + .75rem);left:0;min-width:250px;max-width:350px;padding:.75rem 1rem;background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:.375rem;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;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;pointer-events:none}.lock-tooltip:before{content:"";position:absolute;bottom:100%;left:.5rem;border:5px solid transparent;border-bottom-color:var(--color-warning)}.locked-indicator:hover .lock-tooltip{visibility:visible}.workspace-icon-btn{width:2rem;height:2rem;padding:0;border:1px solid var(--color-gray-300);border-radius:.375rem;background:var(--color-background);cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);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{position:absolute;top:-6px;right:-6px;min-width:16px;height:16px;padding:0 4px;background:var(--color-danger);color:var(--color-text-inverse);border-radius:8px;font-size:var(--font-size-2xs);font-weight:var(--font-weight-semibold);display:flex;align-items:center;justify-content:center;line-height:var(--line-height-none);border:2px solid var(--color-background);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{display:flex;gap:.25rem;padding:.25rem;background:var(--color-gray-100);border-radius:.375rem}.mode-btn{width:2rem;height:2rem;padding:0;border:none;background:transparent;cursor:pointer;border-radius:.25rem;transition:all .15s;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.mode-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text-primary)}.mode-btn.active{background:var(--color-background);box-shadow:0 1px 2px #0000000d;color:var(--color-primary-500)}.mode-btn:disabled{opacity:.5;cursor:not-allowed}.dependency-warning{padding:1rem 1.5rem;background:var(--color-warning-light);border-bottom:1px solid var(--color-warning);color:var(--color-warning-dark);font-size:var(--font-size-sm)}.page-error{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--color-danger-light);border-bottom:1px solid var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm)}.page-content{flex:1 1 auto;overflow:hidden;min-width:0;width:100%}.editor-only{position:relative;height:100%;padding:0;overflow:hidden;box-sizing:border-box;display:flex;flex-direction:column}.editor-container{position:relative;flex:1;overflow:hidden;display:flex;flex-direction:column}.split-editor{height:100%;width:100%;min-width:0;overflow:hidden}.preview-resize-handle{width:4px;background:var(--color-border);cursor:col-resize;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;min-width:0;position:relative;width:100%;height:100%;overflow:hidden}.editor-section{padding:0;display:flex;flex-direction:column}.editor-section .editor-container{position:relative;flex:1;overflow:hidden;display:flex;flex-direction:column}.split-editor .preview-section{padding:1.5rem;overflow-y:auto;overflow-x:hidden}.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{position:absolute;inset:0;background:#3b82c41a;border:2px dashed var(--color-primary-500);display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:10}.drag-overlay-content{text-align:center;color:var(--color-primary-500)}.drag-overlay-content svg{margin-bottom:.5rem}.drag-overlay-content p{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}.upload-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:20}.upload-spinner{padding:1rem 2rem;background:var(--color-background);border-radius:.375rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auto-save-indicator{position:absolute;bottom:1.5rem;right:1.5rem;font-size:var(--font-size-xs);color:var(--color-text-secondary);background:#ffffffe6;padding:.25rem .5rem;border-radius:.25rem;border:1px solid var(--color-border);pointer-events:none;display:flex;align-items:center;gap:.375rem}.sync-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.sync-saved{background-color:var(--color-success)}.sync-saving{background-color:var(--color-warning);animation:pulse-dot 1s ease-in-out infinite}.sync-error{background-color:var(--color-danger)}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.markdown-preview{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-gray-700);width:100%;box-sizing:border-box;overflow-wrap:break-word;word-wrap:break-word}.markdown-preview>*{max-width:100%}.markdown-view>*{max-width:100%}.markdown-view{padding:1.5rem;overflow-y:auto;overflow-x:hidden;height:100%;width:100%;box-sizing:border-box;min-width:0;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}.ai-edit-highlight-line{background-color:#fb923c26;border-radius:3px;animation:ai-line-highlight-fade 5s ease-out forwards}@keyframes ai-line-highlight-fade{0%{background-color:#fb923c26}70%{background-color:#fb923c26}to{background-color:transparent}}.markdown-preview h1,.markdown-view h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);margin:1.5rem 0 1rem;color:var(--color-text-primary)}.markdown-preview h2,.markdown-view h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);margin:1.25rem 0 .75rem;color:var(--color-text-primary)}.markdown-preview h3,.markdown-view h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:1rem 0 .5rem;color:var(--color-text-primary)}.markdown-preview code,.markdown-view code{background:var(--color-gray-100);padding:.125rem .375rem;border-radius:.25rem;font-family:var(--font-family-mono);font-size:.875em}.markdown-preview pre,.markdown-view pre{background:var(--color-gray-800);color:var(--color-gray-100);padding:1rem;border-radius:.375rem;overflow-x:auto;margin:1rem 0;max-width:100%}.markdown-preview pre code,.markdown-view pre code{background:transparent;padding:0;color:inherit}.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{list-style-type:circle;margin:.25rem 0}.markdown-preview ul ul ul,.markdown-view ul ul ul{list-style-type:square}.markdown-preview ol ol,.markdown-view ol ol{list-style-type:lower-alpha;margin:.25rem 0}.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);padding-left:1rem;margin:1rem 0;color:var(--color-text-secondary)}.markdown-preview table,.markdown-view table{width:100%;max-width:100%;border-collapse:collapse;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);padding:.5rem;text-align:left}.markdown-preview th,.markdown-view th{background:var(--color-surface);font-weight:var(--font-weight-semibold)}.view-with-comments{height:100%;width:100%;min-width:0;overflow:hidden}.floating-comment-btn{position:fixed;transform:translate(-50%);display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;background:var(--color-primary-500);color:var(--color-text-inverse);border:none;border-radius:6px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transition:all .2s;z-index:100;animation:fadeInUp .2s ease-out}.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{width:1px;height:24px;background:var(--color-border);margin:0 4px}.agent-toggle-btn{display:flex;align-items:center;gap:4px;padding:4px 8px!important;border-radius:6px;transition:all .2s}.agent-toggle-btn.agent-active{background:var(--color-primary-500)!important;color:var(--color-text-inverse)!important}.agent-toggle-btn.agent-working{animation:agent-pulse 1.5s ease-in-out infinite}.agent-state-indicator{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:10px;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}.agent-state-indicator.agent-working{background:var(--color-primary-100);animation:agent-pulse 1.5s ease-in-out infinite}.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)}@keyframes agent-pulse{0%,to{opacity:1}50%{opacity:.4}}.agent-confirm-modal{max-width:440px}.agent-confirm-modal h3{margin:0 0 12px;font-size:var(--font-size-lg)}.agent-confirm-modal p{margin:8px 0;font-size:var(--font-size-sm);color:var(--color-gray-600)}.agent-confirm-modal ul{margin:8px 0;padding-left:20px;font-size:var(--font-size-sm);color:var(--color-gray-600)}.agent-confirm-modal li{margin:4px 0}.agent-confirm-modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.quick-reply-tabs{display:flex;flex-direction:column;margin-bottom:.5rem;border:1px solid var(--color-border);border-radius:.5rem;overflow:hidden;background:var(--color-background)}.quick-reply-tab-bar{display:flex;border-bottom:1px solid var(--color-border);background:var(--color-surface)}.quick-reply-tab{flex:1;padding:.5rem .625rem;border:none;border-right:1px solid var(--color-border);background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.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{display:flex;flex-direction:column;gap:.375rem;padding:.625rem}.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{display:flex;gap:.375rem;padding:.5rem .625rem;border:1px solid var(--color-gray-300);border-radius:.5rem;background:var(--color-surface);color:var(--color-gray-700);font-size:var(--font-size-sm);line-height:var(--line-height-snug);cursor:pointer;transition:all .15s;text-align:left;width:100%}.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{display:flex;gap:.375rem;align-items:center}.freetext-input{flex:1;padding:.5rem .625rem;border:1px solid var(--color-gray-300);border-radius:.5rem;font-size:var(--font-size-sm);color:var(--color-gray-700);background:var(--color-background);outline:none;transition:border-color .15s}.freetext-input:focus{border-color:var(--color-primary-300)}.freetext-input::placeholder{color:var(--color-text-tertiary)}.freetext-send{padding:.5rem .75rem;border:1px solid var(--color-primary-500);border-radius:.5rem;background:var(--color-primary-500);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s;flex-shrink:0}.freetext-send:hover:not(:disabled){background:var(--color-primary-600)}.freetext-send:disabled{opacity:.5;cursor:not-allowed}.quick-reply-submit{margin:0 .625rem .625rem;padding:.5rem .75rem;border:none;border-radius:.375rem;background:var(--color-success-dark);color:var(--color-text-inverse);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;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);border-radius:.5rem;background:var(--color-surface);margin-bottom:.75rem;overflow:hidden}.plan-card-body{padding:.75rem;max-height:300px;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{display:flex;flex-direction:column;gap:.375rem}.plan-step{display:flex;align-items:baseline;gap:.375rem;font-size:var(--font-size-sm);line-height:var(--line-height-snug)}.plan-step-number{color:var(--color-text-tertiary);font-size:var(--font-size-xs);flex-shrink:0;min-width:1rem;text-align:right}.plan-action-badge{flex-shrink:0;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:.0625rem .375rem;border-radius:9999px;text-transform:lowercase}.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);padding:.5rem .75rem;background:var(--color-background)}.plan-actions-row{display:flex;gap:.5rem;align-items:center}.plan-btn{padding:.375rem .75rem;border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s;border:none;white-space:nowrap}.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{flex:1;display:flex;align-items:center;border:1px solid var(--color-gray-300);border-radius:.375rem;overflow:hidden;transition:border-color .15s,box-shadow .15s}.plan-feedback-input-wrapper:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 2px #3b82c426}.plan-feedback-input{flex:1;padding:.375rem .5rem;border:none;outline:none;font-size:var(--font-size-sm);font-family:inherit;min-width:0}.plan-feedback-input::placeholder{color:var(--color-text-tertiary)}.plan-feedback-send{display:flex;align-items:center;justify-content:center;padding:.375rem;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;transition:color .15s}.plan-feedback-send:hover:not(:disabled){color:var(--color-primary-500)}.plan-feedback-send:disabled{opacity:.3;cursor:not-allowed}.right-panel{display:flex;flex-direction:column;height:100%;background:var(--color-background);border-left:none}.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{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border);background:var(--color-background)}.chat-header h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.chat-header-actions{display:flex;align-items:center;gap:.375rem}.btn-plan-mode{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);background:var(--color-background);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.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{padding:.375rem 1rem;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}.btn-clear{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);background:var(--color-background);color:var(--color-danger-dark);cursor:pointer;transition:all .15s}.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{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-danger-light);border-bottom:1px solid var(--color-danger-light);color:var(--color-danger-dark);font-size:var(--font-size-sm)}.btn-dismiss-error{width:1.5rem;height:1.5rem;border:none;background:transparent;color:var(--color-danger-dark);font-size:var(--font-size-xl);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:.25rem;transition:background .15s}.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:recoveryPulse 2s ease-in-out infinite}@keyframes recoveryPulse{0%,to{opacity:1}50%{opacity:.7}}.chat-messages{flex:1;overflow-y:auto;padding:1rem;background:var(--color-surface)}.no-messages{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-tertiary);font-size:var(--font-size-sm);text-align:center;padding:2rem}.message{margin-bottom:1rem;padding:.75rem;border-radius:.5rem;background:var(--color-background);border:1px solid var(--color-border)}.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{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.message-role{display:flex;align-items:center;gap:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700)}.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{margin:.75rem 0 .5rem;font-weight:var(--font-weight-semibold)}.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{background:#0000000d;padding:.125rem .375rem;border-radius:.25rem;font-family:var(--font-family-mono);font-size:var(--font-size-sm)}.message-content pre{background:var(--color-gray-800);color:var(--color-gray-100);padding:.75rem;border-radius:.375rem;overflow-x:auto;margin:.5rem 0}.message-content pre code{background:transparent;padding:0;color:inherit}.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{list-style-type:circle;margin:.25rem 0}.message-content ul ul ul{list-style-type:square}.message-content ol ol{list-style-type:lower-alpha;margin:.25rem 0}.message-content ol ol ol{list-style-type:lower-roman}.thinking-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 0}.dot{width:8px;height:8px;background:var(--color-text-secondary);border-radius:50%;animation:dotMove 2s ease-in-out infinite}.dot-1{animation-delay:0s}.dot-2{animation-delay:.2s}.dot-3{animation-delay:.4s}@keyframes dotMove{0%,to{transform:translate(0);opacity:.4}10%{transform:translate(3px,-5px);opacity:.7}20%{transform:translate(-2px,4px);opacity:1}30%{transform:translate(5px,2px);opacity:.8}40%{transform:translate(-3px,-3px);opacity:.6}50%{transform:translate(2px,5px);opacity:.9}60%{transform:translate(-4px,-2px);opacity:.7}70%{transform:translate(4px,3px);opacity:.5}80%{transform:translate(-1px,-4px);opacity:.8}90%{transform:translate(2px,1px);opacity:.6}}.tool-indicators{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.tool-indicator{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-snug)}.tool-indicator-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tool-indicator-dot.running{background:var(--color-primary-500);animation:toolDotBlink 1s ease-in-out infinite}.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;overflow-y:auto;padding:.5rem 1rem}.todo-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.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{display:flex;flex-direction:column;gap:.125rem}.todo-item{display:flex;align-items:flex-start;gap:.375rem;padding:.1875rem 0;font-size:var(--font-size-sm);line-height:var(--line-height-snug)}.todo-checkbox{color:var(--color-text-tertiary);flex-shrink:0;font-size:var(--font-size-sm);line-height:var(--line-height-snug)}.todo-checkbox.checked{color:var(--color-success)}.todo-text{color:var(--color-gray-700);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.todo-text.done{text-decoration:line-through;color:var(--color-text-tertiary)}.todo-item.in-progress .todo-checkbox{color:var(--color-primary-500);animation:todoBlink 1s ease-in-out infinite}@keyframes todoBlink{0%,to{opacity:1}50%{opacity:.3}}.todo-animate-add{animation:todoSlideIn .3s ease-out}@keyframes todoSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.todo-animate-done .todo-checkbox{animation:todoCheckPop .4s ease-out}@keyframes todoCheckPop{0%{transform:scale(1)}50%{transform:scale(1.4)}to{transform:scale(1)}}.chat-input-container{padding:1rem;border-top:1px solid var(--color-border);background:var(--color-background)}.chat-offline-notice{display:flex;align-items:center;gap:6px;padding:6px 10px;margin-bottom:8px;font-size:var(--font-size-xs);color:var(--color-warning-dark);background-color:var(--color-warning-light);border-radius:6px;border:1px solid var(--color-warning)}.chat-input{width:100%;padding:.75rem;border:1px solid var(--color-gray-300);border-radius:.375rem;font-size:var(--font-size-sm);font-family:inherit;resize:vertical;min-height:60px;max-height:150px;margin-bottom:.5rem}.chat-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:var(--shadow-focus)}.chat-input:disabled{background:var(--color-gray-100);cursor:not-allowed}.btn-send{display:flex;align-items:center;justify-content:center;gap:.375rem;width:100%;padding:.625rem;background:var(--color-primary-500);color:var(--color-text-inverse);border:none;border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:background .15s}.btn-send:hover:not(:disabled){background:var(--color-primary-600)}.btn-send:disabled{opacity:.5;cursor:not-allowed}.image-suggestion-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.image-suggestion-modal{background:var(--color-background);border-radius:.5rem;box-shadow:var(--shadow-xl);max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.image-suggestion-header{padding:1.5rem;border-bottom:1px solid var(--color-border)}.image-suggestion-header h3{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.image-suggestion-body{padding:1.5rem;overflow-y:auto}.image-suggestion-text{font-size:var(--font-size-base);color:var(--color-gray-700);margin:0 0 1.5rem;line-height:var(--line-height-normal)}.image-suggestion-details{display:flex;flex-direction:column;gap:1rem}.detail-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:.375rem;padding:.75rem}.detail-item strong{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-gray-700);margin-bottom:.5rem}.prompt-preview,.reason-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;line-height:var(--line-height-normal)}.image-suggestion-footer{display:flex;gap:.75rem;padding:1.5rem;border-top:1px solid var(--color-border);background:var(--color-surface)}.image-suggestion-footer .btn-secondary,.image-suggestion-footer .btn-primary{flex:1;padding:.625rem 1rem;border-radius:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s;border:none;display:flex;align-items:center;justify-content:center;gap:.5rem}.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{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-text-inverse);border-radius:50%;animation:spin .8s linear infinite}.continuation-prompt{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;margin-bottom:.5rem;background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:6px;font-size:var(--font-size-sm);color:var(--color-warning-dark)}.btn-continue{padding:.35rem .75rem;background:var(--color-warning);color:var(--color-text-inverse);border:none;border-radius:4px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;white-space:nowrap}.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{display:flex;align-items:baseline;gap:.5rem}.page-type-count-badge{display:inline-flex;align-items:center;padding:.125rem .5rem;font-size:.75rem;font-weight:500;color:var(--color-text-secondary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px}.page-type-header-actions{display:flex;align-items:center;gap:.5rem}.page-type-overview-add{margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border-light)}.activity-meta{display:flex;align-items:center;gap:8px}.activity-page-link{background:none;border:none;padding:0;font-size:var(--font-size-xs);color:var(--color-primary-500);cursor:pointer;text-decoration:underline}.activity-page-link:hover{color:var(--color-primary-700)}.project-summary-card{border:1px solid var(--color-border);border-radius:.5rem;padding:1rem;background:var(--color-background);box-shadow:0 1px 3px #0000000a}.project-summary-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.project-summary-header .phase-overview-card-title{margin:0}.project-summary-regenerate{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-border);border-radius:.375rem;background:var(--color-background);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.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:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.project-summary-error{padding:.5rem .75rem;background:var(--color-danger-light);border-radius:.375rem;color:var(--color-danger-dark);font-size:var(--font-size-sm);margin-bottom:.5rem}.project-summary-skeleton{display:flex;flex-direction:column;gap:.5rem}.skeleton-line{height:14px;background:var(--color-border);border-radius:4px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.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{display:-webkit-box;-webkit-line-clamp:12;-webkit-box-orient:vertical;overflow:hidden}.project-summary-content.clamped:after{content:"";position:absolute;bottom:0;left:0;right:0;height:2.5rem;background:linear-gradient(transparent,var(--color-background));pointer-events:none}.project-summary-toggle{display:block;width:100%;padding:.375rem;margin-top:.25rem;border:none;background:none;color:var(--color-primary-500);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;text-align:center}.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{display:flex;flex-direction:column;gap:.75rem}.project-phase-progress-row{display:flex;flex-direction:column;gap:.25rem}.project-phase-progress-header{display:flex;justify-content:space-between;align-items:baseline}.project-phase-progress-name{font-size:var(--font-size-sm);color:var(--color-gray-700);font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.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{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.125rem}.project-phase-state-chips .phase-state-chip{font-size:10px;padding:1px 6px}.project-phase-empty{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic}.project-action-items{display:flex;flex-direction:column;gap:0}.project-action-item{display:flex;align-items:flex-start;gap:.625rem;padding:.5rem .625rem;border-bottom:1px solid var(--color-gray-100);border-radius:.25rem}.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{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.125rem}.project-phase-col{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.project-health-score-card{margin-bottom:1rem}.project-health-score-layout{display:grid;grid-template-columns:1fr 1fr;gap:1rem;align-items:center}.project-health-score-gauge{display:flex;flex-direction:column;align-items:center;justify-content:center}.project-health-score-gauge .project-score-gauge{width:100%}.project-health-score-radar{min-width:0}@media(max-width:700px){.project-health-score-layout{grid-template-columns:1fr}}.project-health-score-subtitle{text-align:center;font-size:11px;color:var(--color-text-tertiary);margin:.25rem 0 0}.project-score-gauge{margin:0 auto}.project-score-gauge-label{display:block;text-align:center;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:-.25rem;margin-bottom:.5rem}.project-criteria-radar{margin-top:.25rem}.state-dist{display:flex;flex-direction:column;gap:.625rem}.state-dist-bar{display:flex;height:28px;border-radius:6px;overflow:hidden;box-shadow:inset 0 1px 2px #0000000f;border:1px solid rgba(0,0,0,.04)}.state-dist-segment{display:flex;align-items:center;justify-content:center;transition:opacity .15s,transform .15s;cursor:default;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{font-size:11px;font-weight:600;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.2);pointer-events:none}.state-dist-float-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);white-space:nowrap;background:var(--color-gray-800);color:var(--color-text-inverse);font-size:11px;padding:.25rem .5rem;border-radius:4px;pointer-events:none;z-index:var(--z-index-tooltip);box-shadow:0 2px 8px #00000026}.state-dist-float-tooltip strong{font-weight:var(--font-weight-semibold)}.state-dist-legend{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center}.state-dist-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .5rem;border-radius:var(--border-radius-full);border:1px solid var(--color-border);background:var(--color-background);font-size:11px;color:var(--color-text-secondary);cursor:default;transition:all .15s;line-height:1}.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{width:7px;height:7px;border-radius:var(--border-radius-full);flex-shrink:0}.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{display:flex;flex-direction:column;height:calc(100vh - 65px);overflow:hidden}.workspace-panels{flex:1;overflow:hidden}.workspace-panel{overflow:hidden;background:var(--color-background)}.workspace-panel-middle{container-type:inline-size;container-name:middle-panel}.workspace-resize-handle{width:1px;background:var(--color-border);cursor:col-resize;transition:background .2s}.workspace-resize-handle:hover{width:3px;background:var(--color-text-tertiary)}.workspace-loading,.workspace-error{display:flex;align-items:center;justify-content:center;height:calc(100vh - 64px);font-size:var(--font-size-lg);color:var(--color-text-secondary)}.workspace-error{color:var(--color-danger-dark)}.breadcrumbs{display:flex;align-items:center}.breadcrumbs-list{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap;list-style:none;margin:0;padding:0}.breadcrumb-item{display:flex;align-items:center;gap:var(--spacing-2)}.breadcrumb-link{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-base);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--border-radius-sm)}.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(max-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);margin:0 auto;width:100%;overflow-x:hidden}.editor-header{display:flex;flex-direction:column;gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.editor-header-content{display:flex;align-items:center;gap:var(--spacing-4)}.editor-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--border-radius-lg);background:linear-gradient(135deg,var(--color-primary-500) 0%,var(--color-primary-600) 100%);color:var(--color-text-inverse);flex-shrink:0}.editor-actions{display:flex;align-items:center;gap:var(--spacing-3)}.editor-card{min-height:600px;overflow:hidden}.editor-card .cm-editor{border:none;border-radius:0;min-height:600px;height:100%}.editor-card .cm-content{font-family:var(--font-family-mono);font-size:var(--font-size-sm)}@media(max-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{display:inline-flex;align-items:center;justify-content:center;font-weight:var(--font-weight-medium);border-radius:var(--border-radius-full);white-space:nowrap}.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);margin:0 auto;width:100%;overflow-x:hidden}.page-view-actions{display:flex;align-items:center;gap:var(--spacing-3)}.page-view-content{display:flex;flex-direction:column;gap:var(--spacing-6)}.page-metadata{background:linear-gradient(135deg,var(--color-primary-50) 0%,var(--color-background) 100%)}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-6)}.metadata-item{display:flex;align-items:flex-start;gap:var(--spacing-3)}.metadata-icon{color:var(--color-text-secondary);margin-top:2px;flex-shrink:0}.metadata-label{display:block;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)}.metadata-value{display:block;font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.page-content-card{min-height:400px}.page-view-page .page-content{max-width:800px}@media(max-width:768px){.page-view-page{padding:var(--spacing-4)}.metadata-grid{grid-template-columns:1fr;gap:var(--spacing-4)}.page-view-actions{width:100%}.page-view-actions>*{flex:1}}.table-wrapper{width:100%;overflow-x:auto;border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg);-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;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{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12);gap:var(--spacing-4);border:var(--border-width) solid var(--color-border);border-radius:var(--border-radius-lg)}.table-loading-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.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(max-width:768px){.table th,.table td{padding:var(--spacing-3)}.table{font-size:var(--font-size-xs)}.table th{white-space:nowrap}.table td{max-width:200px;overflow:hidden;text-overflow:ellipsis}}@media(max-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{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) var(--spacing-6);text-align:center}.empty-state-icon{display:flex;align-items:center;justify-content:center;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)}.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);margin:0 auto;width:100%;overflow-x:hidden}.settings-tabs{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border);overflow-x:auto}.settings-tab{display:flex;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);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.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{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-6);border-bottom:var(--border-width) solid var(--color-border)}.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{display:flex;align-items:center;gap:var(--spacing-2)}.settings-table-wrapper{position:relative}.settings-table-wrapper .table th:last-child{background:transparent;border-left:none;padding-left:var(--spacing-6)}.table-actions-cell{background:transparent!important;border-left:none!important;border-bottom:none!important;padding-left:var(--spacing-6)!important;width:100px;vertical-align:middle}.settings-table-wrapper .table td:nth-last-child(2),.settings-table-wrapper .table th:nth-last-child(2){border-right:none}.row-actions-container{display:flex;align-items:center;gap:var(--spacing-2);justify-content:flex-end;opacity:.6;transition:opacity var(--transition-base)}.row-actions-container:hover,.table tbody tr:hover .row-actions-container{opacity:1}@media(max-width:768px){.settings-table-wrapper .table th:last-child{padding-left:var(--spacing-3)}.table-actions-cell{padding-left:var(--spacing-3)!important;width:auto}.row-actions-container{opacity:1;justify-content:center}}.table-type-icon{display:inline-flex;vertical-align:middle;margin-right:var(--spacing-2);color:var(--color-text-secondary)}.draggable-cell{display:flex;align-items:center;gap:var(--spacing-2)}.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(max-width:768px){.settings-table-wrapper tr[draggable=true]{cursor:default}.drag-handle{display:none}}.form-fields{display:flex;flex-direction:column;gap:var(--spacing-6)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-2)}.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{display:flex;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}.form-checkbox-label input[type=checkbox]{width:16px;height:16px;min-width:16px;margin:0;cursor:pointer;accent-color:var(--color-primary-500);flex-shrink: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);outline:none;cursor:pointer}.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);outline:none;line-height:var(--line-height-relaxed)}.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{display:flex;flex-direction:column;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)}.checkbox-item{display:flex;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}.checkbox-item:hover{background-color:var(--color-surface-hover)}.checkbox-item input[type=checkbox]{width:16px;height:16px;min-width:16px;margin:0;flex-shrink:0;cursor:pointer;accent-color:var(--color-primary-500)}.checkbox-item span{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-normal);color:var(--color-text-primary);line-height:var(--line-height-normal)}@media(max-width:768px){.settings-page{padding:var(--spacing-4)}.settings-tabs{gap:0;-webkit-overflow-scrolling:touch}.settings-tab{flex:1;justify-content:center;padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}.settings-tab span{display:none}.tab-header{flex-direction:column;gap:var(--spacing-4)}.tab-title{font-size:var(--font-size-xl)}.table-actions{flex-direction:column;align-items:stretch;gap:var(--spacing-2)}.table-actions>*{width:100%}.table-actions button{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-xs)}}@media(max-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{display:flex;flex-direction:column;gap:var(--spacing-2)}.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{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4)}.intg-row-left{display:flex;align-items:center;gap:var(--spacing-3)}.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{display:flex;align-items:center;gap:var(--spacing-2)}.intg-status{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.intg-status--connected{display:inline-flex;align-items:center;gap:4px;color:var(--color-success-dark, #16a34a)}.intg-status--unavailable{color:var(--color-text-tertiary)}.intg-details{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-top:var(--border-width) solid var(--color-border-light, #f3f4f6)}.intg-capabilities{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.intg-cap-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-right:var(--spacing-3)}.intg-details-actions{display:flex;gap:var(--spacing-2);flex-shrink:0}.integration-direction-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:3px;font-size:var(--font-size-xs);font-weight:600;white-space:nowrap;flex-shrink:0}.integration-direction-badge.context{border:1px solid #3b82f6;background:#3b82f61a;color:#3b82f6}.integration-avatar{width:24px;height:24px;border-radius:50%}.not-found-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 64px)}.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);display:block;margin-bottom:var(--spacing-4)}.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{min-height:100vh;background-color:var(--color-surface);display:flex;flex-direction:column;overflow-x:hidden;width:100%;max-width:100vw}.main-content{flex:1;min-height:calc(100vh - 64px);overflow-x:hidden;width:100%;max-width:100%}.main-content-full{min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-4)}.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);text-decoration:none;border-bottom:1px solid var(--color-primary-300);transition:all var(--transition-base)}.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);font-size:.9em;color:var(--color-danger-dark)}.markdown-viewer pre{background-color:var(--color-gray-900);color:var(--color-gray-100);padding:var(--spacing-4);border-radius:var(--border-radius-md);overflow-x:auto;margin-bottom:var(--spacing-4);border:var(--border-width) solid var(--color-border)}.markdown-viewer pre code{background-color:transparent;padding:0;color:inherit;font-size:var(--font-size-sm)}.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{width:100%;border-collapse:collapse;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{max-width:100%;height:auto;border-radius:var(--border-radius-md);margin:var(--spacing-4) 0}
