* { box-sizing: border-box; }
body { font-family: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, Helvetica, Arial, sans-serif; margin: 0; background: #fafafa; color: #222; }
.container { max-width: 1100px; margin: 0 auto; padding: 0 16px; }
.topbar { background: #111; color: #fff; }
.topbar .bar { display: flex; align-items: center; justify-content: space-between; }
.topbar .left { display: flex; align-items: center; gap: 12px; }
.topbar .brand { color: #fff; text-decoration: none; font-weight: 700; margin-right: 16px; display: inline-block; padding: 12px 0; }
.topbar .search { display: inline-flex; gap: 6px; }
.topbar input { padding: 6px 8px; }
.topbar button { padding: 6px 10px; }
.topbar .logout { color: #fff; text-decoration: none; opacity: 0.9; }
.topbar .logout:hover { opacity: 1; }

h1, h2, h3 { margin: 16px 0 8px; }
.filters { margin: 16px 0; }
.contracts { list-style: none; padding: 0; margin: 0; }
.contracts li { background: #fff; margin: 8px 0; padding: 12px; border-radius: 8px; border: 1px solid #eee; }
.contracts .row { display: flex; gap: 12px; align-items: flex-start; }
.contracts .grow { flex: 1; }
.contracts .title { font-weight: 600; color: #0a58ca; text-decoration: none; }
.contracts .meta { color: #666; font-size: 12px; margin-top: 2px; }
.contracts .summary { margin: 6px 0 0; color: #333; }
.actions a { text-decoration: none; font-size: 12px; }

.badge { display: inline-block; margin-left: 8px; padding: 2px 6px; border-radius: 10px; background: #f0f0f0; color: #333; border: 1px solid #e0e0e0; font-size: 11px; }

.panel { background: #fff; padding: 12px; border: 1px solid #eee; border-radius: 8px; }
.panel input, .panel textarea, .panel select { width: 100%; margin: 4px 0 10px; padding: 8px; }

pre.fulltext { white-space: pre-wrap; background: #fff; padding: 12px; border-radius: 8px; border: 1px solid #eee; }
pre.fulltext.scroll { max-height: 50vh; overflow-y: auto; }
.footer { color: #777; font-size: 12px; padding: 12px 0 40px; }

.alert { padding: 10px 12px; border-radius: 6px; margin: 12px 0; border: 1px solid transparent; }
.alert.info { background: #e7f1ff; border-color: #b9d3ff; color: #084298; }