:root{--color-bg: #f8f9fa;--color-surface: #ffffff;--color-surface-low: #f3f4f5;--color-surface-container: #edeeef;--color-surface-container-high: #e7e8e9;--color-border: #bfc8c6;--color-border-light: #e1e3e4;--color-input-bg: #edeeef;--color-text: #191c1d;--color-text-muted: #404847;--color-outline: #707977;--color-primary: #003633;--color-primary-deep: #134e4a;--color-primary-container: #134e4a;--color-primary-fixed: #b5ede7;--color-on-primary: #ffffff;--color-secondary: #0f172a;--color-on-secondary: #ffffff;--color-success: #10b981;--color-success-bg: #d1fae5;--color-success-text: #065f46;--color-warning-bg: #fef3c7;--color-warning-text: #92400e;--color-error: #ba1a1a;--color-error-bg: #ffdad6;--color-error-text: #93000a;--color-info-bg: #dbeafe;--color-info-text: #1e40af;--font-display: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-headline: "Puritan", Georgia, serif;--font-mono: "Geist Mono", ui-monospace, monospace;--radius-sm: 2px;--radius: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;--shadow-1: 0 4px 6px -1px rgb(0 0 0 / .05)}*{box-sizing:border-box}body{margin:0;font-family:var(--font-display);background:var(--color-bg);background-image:radial-gradient(var(--color-border-light) .5px,transparent .5px);background-size:22px 22px;color:var(--color-text);font-size:14px;line-height:20px}a{color:var(--color-primary)}h1,h2,h3{font-family:var(--font-headline);font-weight:700;letter-spacing:-.01em;color:var(--color-primary);margin:0 0 4px}h1{font-size:28px;line-height:36px}h2{font-size:22px;line-height:30px}h3{font-size:18px;line-height:26px}.icon{font-variation-settings:"opsz" 20;font-size:18px;line-height:1;vertical-align:-3px}.page{max-width:960px;margin:0 auto;padding:32px 24px}.page-wide{max-width:1200px}.dashboard-tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:24px}.dashboard-tile{display:flex;flex-direction:column;align-items:center;gap:8px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:32px 16px;text-decoration:none;color:inherit;transition:border-color .15s ease}.dashboard-tile:hover{border-color:var(--color-primary)}.dashboard-tile .icon{font-size:32px;color:var(--color-primary)}.dashboard-tile-count{font-size:36px;font-weight:600}.dashboard-tile-label{color:var(--color-text-muted)}.dashboard-tile-loading{min-height:140px}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;min-width:0}.topnav{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:4px;padding:0 24px;height:64px;background:var(--color-primary);flex-shrink:0;position:sticky;top:0;z-index:50}.topnav-brand{display:flex;align-items:center;gap:8px;color:#fff;font-family:var(--font-headline);font-weight:700;font-size:19px;letter-spacing:-.01em}.topnav-logo{width:40px;height:40px}.topnav-center{display:flex;gap:4px;justify-self:center}.topnav>a{justify-self:end;color:#ffffffd9;text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.02em;padding:9px 16px;border-radius:var(--radius-full);display:inline-flex;align-items:center;gap:6px}.topnav>a:hover{background:#ffffff1a;color:#fff}.topnav-center>a,.topnav-dropdown>span{color:#ffffffd9;text-decoration:none;font-size:13px;font-weight:700;letter-spacing:.02em;padding:9px 16px;border-radius:var(--radius-full);cursor:pointer;display:inline-flex;align-items:center;gap:4px}.topnav-center>a:hover,.topnav-dropdown>span:hover{background:#ffffff1a;color:#fff}.topnav-center>a.active,.topnav-dropdown>span.active{background:#ffffff29;color:#fff}.topnav-dropdown{position:relative}.topnav-dropdown .icon{font-size:16px;vertical-align:-2px}.tenant-switcher{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-full);font-size:13px;font-weight:700;letter-spacing:.02em;padding:8px 14px;margin-right:8px}.tenant-switcher option{color:var(--color-text)}.topnav-dropdown-menu{display:none;position:absolute;top:100%;left:0;flex-direction:column;min-width:190px;background:var(--color-primary-deep);border-radius:var(--radius-md);padding:6px;box-shadow:0 8px 16px #00000040;z-index:10}.topnav-dropdown:hover .topnav-dropdown-menu{display:flex}.topnav-dropdown-menu a{color:#ffffffd9;text-decoration:none;font-size:14px;padding:8px 12px;border-radius:var(--radius);white-space:nowrap}.topnav-dropdown-menu a:hover{background:#ffffff1f;color:#fff}.topnav-dropdown-menu a.active{background:#ffffff29;color:#fff;font-weight:600}button{cursor:pointer;border:none;border-radius:var(--radius);padding:9px 16px;background:var(--color-primary);color:var(--color-on-primary);font-family:var(--font-display);font-size:14px;font-weight:500;display:inline-flex;align-items:center;gap:6px;transition:background-color .12s ease}button:hover:not(:disabled){background:var(--color-primary-deep)}button:disabled{background:var(--color-outline);color:#fff;cursor:not-allowed}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-secondary{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-container-high);color:var(--color-text)}.btn-ghost{background:transparent;color:var(--color-primary);padding:6px 10px}.btn-ghost:hover:not(:disabled){background:var(--color-surface-low);color:var(--color-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#93000a}.btn-sm{padding:5px 10px;font-size:12px}input,select{padding:9px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-family:var(--font-display);font-size:14px;color:var(--color-text)}input:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #0036331a}table{width:100%;border-collapse:separate;border-spacing:0;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);overflow:hidden}th{text-align:left;padding:12px 16px;border-bottom:1px solid var(--color-border-light);font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);background:var(--color-surface-low)}td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--color-border-light);font-size:14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:var(--color-surface-low)}.customer-group-row{cursor:pointer;background:var(--color-border-light)}.customer-group-row:hover{background:var(--color-surface-container)}.caret{display:inline-flex;margin-right:4px;color:var(--color-text-muted);transition:transform .15s ease}.caret-open{transform:rotate(90deg)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.badge-modified{background:var(--color-warning-bg);color:var(--color-warning-text)}.badge-removed{background:var(--color-error-bg);color:var(--color-error-text)}.badge-added{background:var(--color-info-bg);color:var(--color-info-text)}.badge-unchanged{background:var(--color-border-light);color:var(--color-text-muted)}.badge-ready{background:var(--color-success-bg);color:var(--color-success-text)}.badge-processing{background:var(--color-warning-bg);color:var(--color-warning-text)}.badge-error{background:var(--color-error-bg);color:var(--color-error-text)}.badge-uploaded{background:var(--color-border-light);color:var(--color-text-muted)}.customer-logo{width:32px;height:32px;border-radius:50%;object-fit:cover;display:block}.customer-logo-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-border-light);color:var(--color-text-muted);font-weight:600;font-size:13px}.group-row-logo{display:inline-block;vertical-align:middle;margin-right:8px}.group-row-logo .customer-logo,.group-row-logo .customer-logo-placeholder{width:22px;height:22px;font-size:11px}.logo-upload{display:inline-block;cursor:pointer;border-radius:50%;transition:opacity .15s}.logo-upload:hover{opacity:.7}.doc-headers{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.doc-header{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface)}.doc-header-master{background:var(--color-surface-low);border-color:#bfdbfe}.doc-header-customer{background:var(--color-success-bg);border-color:#a7f3d0}.doc-header-tag{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);white-space:nowrap}.doc-header-name{font-family:var(--font-mono);font-size:13px;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.doc-download-btn{flex-shrink:0}.clause-column-headers{margin-bottom:8px}.clause-column-headers .doc-header-tag{padding:0 16px}.toolbar{display:flex;gap:20px;margin-bottom:16px;flex-wrap:wrap}.toggle-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px 16px;background:var(--color-surface)}.toggle-group legend{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);padding:0 4px}.toggle-buttons{display:flex;gap:8px}.toggle-hint{margin:8px 0 0;font-size:12px;color:var(--color-text-muted);max-width:260px}.clause-section{display:inline-block;font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--color-text-muted);margin-right:6px}.risk-badge-low{background:var(--color-success-bg);color:var(--color-success-text)}.risk-badge-medium{background:var(--color-warning-bg);color:var(--color-warning-text)}.risk-badge-high{background:var(--color-error-bg);color:var(--color-error-text)}.clause-block{border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:16px;overflow:hidden;background:var(--color-surface)}.clause-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-border-light);cursor:pointer}.clause-body{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--color-border)}.clause-side{background:var(--color-surface);padding:14px 16px;font-size:13px;white-space:pre-wrap}.clause-side.empty{color:var(--color-text-muted);font-style:italic}.source-item{border-radius:var(--radius)}.source-item-text{margin:6px 0 4px 4px;padding:10px 12px;background:var(--color-bg);border-left:2px solid var(--color-border);border-radius:var(--radius-sm);font-size:12px;color:var(--color-text);white-space:pre-wrap}.clause-side-section{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--color-text-muted);margin-bottom:4px}.word-insert{background:var(--color-info-bg);color:var(--color-info-text)}.word-delete{background:var(--color-error-bg);color:var(--color-error-text);text-decoration:line-through}.word-punctuation{outline:1px dashed currentColor;outline-offset:1px}.summary-panel{background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:20px;font-size:14px;line-height:1.5}.summary-panel-title{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted);display:inline-flex;align-items:center;gap:6px}.summary-markdown{margin-top:8px}.summary-markdown h1,.summary-markdown h2,.summary-markdown h3{font-size:14px;margin:14px 0 6px;color:var(--color-text)}.summary-markdown p{margin:0 0 10px}.summary-markdown ul,.summary-markdown ol{margin:0 0 10px;padding-left:20px}.summary-markdown li{margin-bottom:4px}.summary-markdown strong{font-weight:700}.summary-collapsed{max-height:90px;overflow:hidden;position:relative;-webkit-mask-image:linear-gradient(to bottom,black 50%,transparent 100%);mask-image:linear-gradient(to bottom,black 50%,transparent 100%)}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.chat-page{max-width:1400px}.chat-layout{display:flex;gap:24px;align-items:flex-start}.chat-sidebar{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:12px;position:sticky;top:24px}.chat-sidebar-list{display:flex;flex-direction:column;gap:2px;max-height:calc(100vh - 160px);overflow-y:auto}.chat-sidebar-item{background:transparent;border-radius:var(--radius);display:flex;align-items:center;gap:2px;width:100%}.chat-sidebar-item:hover{background:var(--color-surface-low)}.chat-sidebar-item.active{background:var(--color-surface-container)}.chat-sidebar-item-main{background:transparent;color:var(--color-text);padding:8px 10px;display:flex;flex:1;min-width:0;flex-direction:column;align-items:flex-start;gap:2px;text-align:left}.chat-sidebar-item-main:hover:not(:disabled){background:transparent}.chat-sidebar-item-close{background:transparent;color:var(--color-text-muted);padding:6px;flex-shrink:0;margin-right:4px;opacity:0}.chat-sidebar-item:hover .chat-sidebar-item-close{opacity:1}.chat-sidebar-item-close:hover:not(:disabled){color:var(--color-error-text);background:var(--color-error-bg)}.chat-sidebar-item-title{font-size:13px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.chat-sidebar-item-date{font-size:11px;color:var(--color-text-muted)}.chat-main{flex:1;min-width:0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center}.modal{background:var(--color-surface);border-radius:var(--radius-md);padding:24px;width:420px;display:flex;flex-direction:column;gap:12px;box-shadow:0 20px 40px #0003}
