/* Global Theme */
/* Sansation font faces */
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-Regular.ttf') format('truetype');
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-Italic.ttf') format('truetype');
  font-weight:400; font-style:italic; font-display:swap;
}
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-Bold.ttf') format('truetype');
  font-weight:700; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-BoldItalic.ttf') format('truetype');
  font-weight:700; font-style:italic; font-display:swap;
}
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-Light.ttf') format('truetype');
  font-weight:300; font-style:normal; font-display:swap;
}
@font-face{
  font-family:'sansationregular';
  src: url('fonts/Sansation-LightItalic.ttf') format('truetype');
  font-weight:300; font-style:italic; font-display:swap;
}
:root{
  --bg:#f3f4f6; --text:#111827; --muted:#6b7280; --blue:#2563eb; --blue-2:#1d4ed8; --green:#16a34a; --gray:#e5e7eb; --white:#fff; --shadow:0 8px 24px rgba(0,0,0,0.12);
  /* Brand-specific tones approximating the sample */
  --brand-blue:#2b4a8a; /* dark slate blue */
  --brand-green:#a3cf2e; /* vivid lime green */
  --chat-width: clamp(380px, 52vw, 560px);
  /* Sky palette for action pills */
  --sky:#38bdf8; /* sky-400 */
  --sky-2:#0ea5e9; /* sky-500 */
  /* Unified header/tabs backdrop (slightly darker than #dae5ff) */
  --box-header:#c9d9ff;
  /* Slightly lighter than box header for clause title tabs */
  --box-header-light:#d7e2ff;
  /* Scrollbar palette */
  --scroll-track:rgba(15,23,42,0.03);
  --scroll-thumb:rgba(43,74,138,0.28);
  --scroll-thumb-hover:rgba(43,74,138,0.55);
}
html,body{height:100%}
html{scroll-behavior:smooth}
body{margin:0;font-family: 'sansationregular', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;background:var(--bg);color:var(--text);font-size:16px}
*{
  scrollbar-width:thin;
  scrollbar-color:var(--scroll-thumb) transparent;
}
*::-webkit-scrollbar{
  width:6px;
  height:6px;
}
*::-webkit-scrollbar-track{
  background:var(--scroll-track);
  border-radius:999px;
}
*::-webkit-scrollbar-thumb{
  background:var(--scroll-thumb);
  border-radius:999px;
}
*::-webkit-scrollbar-thumb:hover{
  background:var(--scroll-thumb-hover);
}
.page{min-height:100%;display:flex;flex-direction:column}
header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:24px 30px; background:#fff; box-shadow:0 2px 6px rgba(0,0,0,0.06)}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--blue)}
.logo img{display:none}
.logo .wordmark{display:none}
/* Branded text logo (no arrows) */
.brand{display:inline-flex;align-items:center;font-weight:900;font-size:36px;letter-spacing:0.2px;line-height:1; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale}
.brand .leg{color:var(--brand-blue)}
.brand .dox{color:var(--brand-green)}
.hero{flex:1;display:flex;align-items:center;justify-content:flex-start;padding:40px 60px}
.hero .welcome{font-size:36px;font-weight:700;opacity:0.85}
.notice{font-size:12px;color:var(--muted);padding:8px 12px}
.link{color:var(--blue-2);text-decoration:none}

/* Layout: Left Panel + Right Chat */
.doc-panel{position:absolute;left:24px;top:120px;bottom:24px;width:calc(100vw - var(--chat-width) - 72px);background:var(--white);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.doc-panel--library{padding:0;overflow:hidden;display:flex;flex-direction:column}
.doc-viewer-only{flex:1;display:flex;flex-direction:column;height:100%}
.doc-library-viewer{flex:1;display:flex;flex-direction:column;background:#fff;height:100%}
.doc-viewer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;background:var(--box-header);padding:26px 30px;border-bottom:1px solid rgba(15,23,42,0.08)}
.doc-viewer-label{font-size:26px;font-weight:800;color:#0f172a;margin:0}
.doc-viewer-meta{font-size:14px;color:#475569;margin-top:6px;max-width:460px}
.doc-viewer-body{flex:1;padding:0;background:#f8f9ff;position:relative}
.doc-viewer-frame{width:100%;height:100%;border:0;display:block}
.doc-viewer-frame.is-hidden{display:none}
.doc-viewer-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;color:#475569;padding:40px}
.doc-viewer-placeholder.is-hidden{display:none}
.doc-viewer-placeholder .doc-page-label{font-size:13px;text-transform:uppercase;letter-spacing:0.12em;font-weight:700;color:#1e1b4b}
.doc-viewer-link{font-size:14px;font-weight:600;color:var(--brand-blue);text-decoration:none;border:1px solid rgba(15,23,42,0.2);padding:8px 18px;border-radius:20px;transition:all .2s ease}
.doc-viewer-link:hover{background:rgba(15,23,42,0.08)}
.doc-viewer-link.is-disabled{pointer-events:none;opacity:0.4}
.doc-answer-meta{margin-top:4px}
.doc-citation-list{margin:0;padding-left:24px;display:flex;flex-direction:column;gap:10px;font-size:15px;color:#0f172a;line-height:1.5;letter-spacing:0.2px}
.doc-context-list{display:flex;flex-direction:column;gap:18px;padding-right:0}
.doc-context-item{border:1px solid rgba(43,74,138,0.15);border-radius:20px;background:#fff;box-shadow:0 10px 28px rgba(15,23,42,0.08);display:flex;flex-direction:column}
.doc-context-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 22px;background:#f0f4ff;border-bottom:1px solid rgba(15,23,42,0.06)}
.doc-context-title{font-weight:800;font-size:16px;color:#0f172a;margin:0}
.doc-context-subtitle{font-size:13px;color:#475569;margin-top:3px}
.doc-context-type{display:inline-flex;align-items:center;font-size:13px;font-weight:600;color:#1d2a66;background:#e0e7ff;border-radius:999px;padding:4px 14px;white-space:nowrap}
.doc-context-body{padding:22px 24px;background:#fff;display:flex;flex-direction:column;gap:16px}
.doc-context-meta-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px}
.doc-context-meta-item{padding:12px 14px;border:1px solid rgba(15,23,42,0.08);border-radius:14px;background:#f8f9ff;display:flex;flex-direction:column;gap:4px}
.doc-context-meta-label{font-size:12px;text-transform:uppercase;letter-spacing:0.05em;color:#475569}
.doc-context-meta-value{font-size:15px;font-weight:600;color:#0f172a}
.doc-context-text{font-size:15.5px;line-height:1.68;color:#0f172a;white-space:normal;word-break:break-word;margin:0}
.doc-mode-pills{margin-top:8px;justify-content:flex-start}
.doc-library-empty{padding:32px}
.doc-library-empty .section-card{max-width:520px;margin:0 auto;text-align:center}
.doc-meta-table{max-height:260px;overflow:auto;border:1px solid var(--gray);border-radius:14px}

/* Analysis Mode */
.doc-panel--analysis{position:absolute;left:24px;top:120px;bottom:24px;width:calc(100vw - var(--chat-width) - 104px);background:linear-gradient(160deg,#ffffff 0%,#f3f6ff 35%,#e8f2ff 100%);border-radius:18px;box-shadow:var(--shadow);padding:22px 26px;overflow:hidden;display:flex;flex-direction:column;gap:12px}
.analysis-head{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:10px 4px 6px;border-bottom:1px solid rgba(15,23,42,0.06)}
.analysis-head .section-title{font-size:22px;font-weight:800;margin:0;color:#0f172a}
.analysis-head .muted{margin-top:6px}
.analysis-status-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border-radius:999px;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.02em;background:#e0e7ff;color:#1d2a66;border:1px solid rgba(29,42,102,0.15)}
.card.analysis-card{border:1px solid rgba(15,23,42,0.06);background:#fff;box-shadow:0 12px 32px rgba(15,23,42,0.07);padding:18px 20px;border-radius:16px}
.analysis-card h3{font-size:18px;font-weight:800;color:#0f172a;letter-spacing:0.2px}
.analysis-summary{display:flex;flex-direction:column;gap:10px}
.snw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px;margin-top:12px}
.snw-section{background:#fff;border:1px solid rgba(15,23,42,0.06);border-radius:14px;padding:16px 16px 12px;box-shadow:0 10px 24px rgba(15,23,42,0.05)}
.snw-section h4{margin:0 0 8px;font-size:15px;font-weight:800;color:#0f172a;display:flex;align-items:center;gap:8px}
.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:22px;padding:0 8px;border-radius:999px;background:rgba(37,99,235,0.12);color:#1d4ed8;font-weight:800;font-size:12px}
.spaced-list{list-style:disc;padding-left:20px;display:flex;flex-direction:column;gap:10px;margin:8px 0 0;font-size:15px;line-height:1.55;color:#0f172a}
.analysis-empty{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:15px;padding:14px 10px}
.analysis-empty .dot{width:10px;height:10px;border-radius:50%;background:#cbd5e1}
.analysis-tabs{display:flex;gap:10px;padding:0 4px 8px}
.analysis-tab-btn{padding:10px 16px;border:1px solid #c8d3f5;border-radius:12px;background:rgba(201,217,255,0.6);color:#111;cursor:pointer;font-weight:700;font-size:15px;letter-spacing:0.1px;user-select:none;transition:all .15s ease}
.analysis-tab-btn:hover{border-color:#cbd5e1}
.analysis-contents{flex:1;overflow:auto;padding:6px 2px 20px}
.analysis-pane{display:none}
.analysis-pane.active{display:block}
.analysis-tabs input[type=radio],
input[name="analysis-tab"]{
  display:none;
  position:absolute;
  opacity:0;
  pointer-events:none;
}
#tab-comp-doc,
#tab-comp-table,
#tab-comp-summary,
#tab-comp-doc-a,
#tab-comp-doc-b,
#tab-obl-obl,
#tab-obl-doc,
input[name="compliance-tab"]{
  display:none;
  position:absolute;
  opacity:0;
  pointer-events:none;
}
#tab-ana-doc:checked ~ .analysis-tabs label[for=tab-ana-doc],
#tab-ana-analysis:checked ~ .analysis-tabs label[for=tab-ana-analysis]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}
#tab-ana-doc:checked ~ .analysis-contents .analysis-pane[data-pane="doc"]{display:block}
#tab-ana-analysis:checked ~ .analysis-contents .analysis-pane[data-pane="analysis"]{display:block}
#tab-comp-doc:checked ~ .analysis-tabs label[for=tab-comp-doc],
#tab-comp-table:checked ~ .analysis-tabs label[for=tab-comp-table]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}
#tab-comp-doc:checked ~ .analysis-contents .analysis-pane[data-pane="doc"]{display:block}
#tab-comp-table:checked ~ .analysis-contents .analysis-pane[data-pane="analysis"]{display:block}
#tab-comp-summary:checked ~ .analysis-tabs label[for=tab-comp-summary],
#tab-comp-doc-a:checked ~ .analysis-tabs label[for=tab-comp-doc-a],
#tab-comp-doc-b:checked ~ .analysis-tabs label[for=tab-comp-doc-b]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}
#tab-comp-summary:checked ~ .analysis-contents .analysis-pane[data-pane="analysis"]{display:block}
#tab-comp-doc-a:checked ~ .analysis-contents .analysis-pane[data-pane="doc"]{display:block}
#tab-comp-doc-b:checked ~ .analysis-contents .analysis-pane[data-pane="doc-b"]{display:block}
#tab-obl-obl:checked ~ .analysis-tabs label[for=tab-obl-obl],
#tab-obl-doc:checked ~ .analysis-tabs label[for=tab-obl-doc]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}
#tab-obl-obl:checked ~ .analysis-contents .analysis-pane[data-pane="analysis"]{display:block}
#tab-obl-doc:checked ~ .analysis-contents .analysis-pane[data-pane="doc"]{display:block}
.doc-meta-table table{width:100%;border-collapse:collapse;font-size:13px}
.doc-meta-table th{background:#f4f6ff;font-weight:700;padding:8px 10px;position:sticky;top:0}
.doc-meta-table td{padding:7px 10px;border-bottom:1px solid var(--gray)}
.viewer--analysis{overflow:hidden}

/* Tabs */
.tab-wrap{display:block; height:100%;}
.tab-wrap input[type=radio]{display:none}
.tabs{display:flex;gap:12px;padding:16px 20px;background:var(--box-header);border-bottom:1px solid var(--gray)}
.tab-btn{padding:12px 22px;border:1px solid #c8d3f5;border-radius:999px;background:var(--box-header);color:#111;cursor:pointer;font-weight:700;font-size:19px;user-select:none;letter-spacing:0.15px}
.tab-btn:hover{border-color:#cbd5e1}

/* Active tab styling */
#tab-overview:checked ~ .tabs label[for=tab-overview],
#tab-doc:checked ~ .tabs label[for=tab-doc],
#tab-attr:checked ~ .tabs label[for=tab-attr],
#tab-clauses:checked ~ .tabs label[for=tab-clauses]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}

#tab-ana-doc:checked ~ .analysis-tabs label[for=tab-ana-doc],
#tab-ana-analysis:checked ~ .analysis-tabs label[for=tab-ana-analysis]{
  background:var(--blue); color:#fff; border-color:var(--blue);
}

.tab-contents{height:100%; overflow:auto; background:#fff; padding-bottom:120px; scroll-padding-bottom:140px}
.tab-contents::after{content:""; display:block; height:24px}
#tab-overview:checked ~ .tab-contents .content-overview{display:block}
#tab-doc:checked ~ .tab-contents .content-doc{display:block}
#tab-attr:checked ~ .tab-contents .content-attr{display:block}
#tab-clauses:checked ~ .tab-contents .content-clauses{display:block}
.tab-content{display:none; padding:24px 24px 64px}

/* Overview */
.overview-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:16px}
.progress-chip{background:#eef2ff;padding:10px 16px;border-radius:999px;font-weight:700;font-size:15px;color:#1e1b4b;letter-spacing:0.2px}
.detail-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.detail-row{display:grid;grid-template-columns:minmax(220px,1.2fr) minmax(190px,1fr) auto;gap:20px;padding:18px 20px;border:1px solid var(--gray);border-radius:16px;align-items:center;background:#fdfdff}
.detail-meta{display:flex;flex-direction:column;gap:8px;justify-content:center}
.detail-name{font-weight:700;font-size:17px;letter-spacing:0.2px}
.detail-value{font-size:16.5px;color:#0f172a;font-weight:600;line-height:1.45;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere;display:flex;align-items:center;justify-content:flex-start}
.detail-value .pre{display:block}
.detail-value .muted{font-style:italic}
.detail-status-icon{font-size:20px;font-weight:700;color:var(--muted)}
.detail-row.completed .detail-status-icon{color:var(--green)}
.badge{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.02em}
.badge-required{background:#fef3c7;color:#92400e}
.detail-options{font-size:14px;color:#566074;font-weight:500;margin-top:4px}
.small{font-size:14px}

/* Comparison summary polish (scoped) */
.comparison-summary-wrap{max-width:1120px;margin:0 auto;width:100%}
.comparison-summary-wrap .card.analysis-card{padding:16px 18px;border-radius:14px;box-shadow:0 10px 26px rgba(15,23,42,0.06)}
.comparison-summary-wrap .analysis-summary{gap:16px}
.comparison-summary-wrap .spaced-list{gap:12px}
.comparison-summary-wrap .spaced-list li{max-width:82ch}

/* Document view */
.doc-head{padding:8px 10px; border:1px solid var(--gray); background:#fafafa; border-radius:8px; display:flex; justify-content:space-between; align-items:center; font-weight:600; margin-bottom:10px}
.viewer{height:64vh; background:#fafafa; border:1px solid var(--gray); border-radius:10px; overflow:auto}
.viewer iframe,.viewer embed{width:100%; height:100%; border:0}
.placeholder{height:100%; display:flex; align-items:center; justify-content:center; color:var(--muted)}
.welcome-card{height:60vh; display:flex; align-items:center; justify-content:center}
.welcome-inner{max-width:80%; text-align:center}
.welcome-inner h2{margin:0 0 8px; font-size:32px; letter-spacing:.2px; color:#111}
.welcome-inner p{margin:0; color:var(--muted)}

/* Sections */
.section-card{background:#fff;border:1px solid var(--gray);border-radius:16px;box-shadow:0 4px 10px rgba(0,0,0,0.04);padding:18px 20px 24px}
.section-title{font-weight:800;margin:0 0 14px;color:#0f172a;font-size:21px;letter-spacing:0.3px}

/* Clause list styling */
.clause-list{display:flex;flex-direction:column;gap:18px;margin-bottom:12px}
.clause-item{border:1px solid rgba(43,74,138,0.18);border-radius:18px;background:#fff;box-shadow:0 6px 20px rgba(15,23,42,0.08);overflow:hidden}
.clause-item summary{display:flex;align-items:flex-start;gap:12px;padding:13px 18px;background:var(--box-header);color:var(--brand-blue);font-weight:800;font-size:16.5px;letter-spacing:0.15px;cursor:pointer;list-style:none}
.clause-item summary::-webkit-details-marker{display:none}
.clause-name{flex:1}
.clause-toggle-icon{width:26px;height:26px;border-radius:50%;border:1px solid rgba(15,23,42,0.25);display:inline-flex;align-items:center;justify-content:center;font-size:14px;transition:transform 0.2s ease}
.clause-item[open] .clause-toggle-icon{transform:rotate(90deg)}
.clause-body{white-space:pre-wrap;line-height:1.65;color:#0f172a;background:#f8fbff;border-top:1px solid #dbe7ff;padding:22px 26px;font-size:16px;max-height:320px;overflow:auto;box-sizing:border-box}
/* Key/Value Grid for Attributes */
.kv-card{border:1px solid var(--gray);border-radius:12px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.04)}
/* Table-style attributes */
.kv-table-wrap{width:100%;overflow:auto}
.kv-table{width:100%;border-collapse:separate;border-spacing:0}
.kv-table tr:nth-child(odd){background:#fbfbfc}
.kv-th{width:230px;padding:4px 10px;color:#6b7280;font-weight:700;text-align:left;vertical-align:top;border-right:1px solid var(--gray)}
.kv-td{padding:4px 10px;color:#0f172a;white-space:pre-wrap;line-height:1.25;word-break:break-word;overflow-wrap:anywhere;text-align:left;vertical-align:top}
.kv-table tr + tr .kv-th,.kv-table tr + tr .kv-td{border-top:1px solid var(--gray)}
.kv-multi{display:flex;flex-direction:column;gap:2px}
.kv-item{margin:0}
/* Bulleted list for iterable values (e.g., Parties) */
.kv-list{margin:0;padding-left:0;list-style-position:inside}
.kv-list li{margin:0 0 2px 0}

/* Form-style attributes (compact, top-left aligned) */
.form-card{border:1px solid var(--gray);border-radius:16px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,0.05)}
.form-rows{display:flex;flex-direction:column;padding-bottom:12px;gap:4px}
.form-row{display:grid;grid-template-columns:260px 1fr;gap:12px 20px;padding:12px 18px;align-items:flex-start}
.form-row:nth-child(odd){background:#fbfbfc}
.form-label{color:#4b5563;font-weight:700;text-align:left;font-size:16px;letter-spacing:0.1px}
.form-value{color:#0f172a;white-space:normal;line-height:1.5;word-break:break-word;overflow-wrap:anywhere;text-align:left;border-left:1px solid var(--gray);padding-left:16px;font-size:16px}
.form-value .pre{display:block}
.form-value ul{margin:0;padding:0;list-style:disc inside;line-height:1.25}
.form-value li{margin:0 0 2px 0}

/* Preserve newlines only where needed */
.pre{white-space:pre-wrap}

/* Chat */
.chat-wrap{position:fixed;right:24px;top:120px;bottom:24px;width:var(--chat-width);height:calc(100vh - 144px);background:var(--white);border-radius:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;z-index:20}
.chat-head{background:var(--box-header);color:#0f172a;padding:18px 22px;font-weight:700;font-size:21px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.chat-title{font-size:23px;font-weight:800;margin:0}
.chat-subtitle{font-size:14px;font-weight:400;color:var(--muted);margin-top:6px}
.mode-pill{background:#eef2ff;color:#1e1b4b;padding:6px 14px;border-radius:999px;font-size:13px;font-weight:700;letter-spacing:0.2px}
.chat-body{flex:1;padding:14px 18px 10px;overflow:auto;display:flex;flex-direction:column;gap:12px}
.bubble{max-width:82%;padding:13px 18px;border-radius:18px;line-height:1.6;font-size:16px;white-space:normal}
.bot{align-self:flex-start;background:#eef2ff;color:#111}
.user{align-self:flex-end;background:var(--blue);color:#fff}
.chat-doc-section{margin:14px 0}
.chat-doc-heading{font-weight:700;margin:2px 0;color:#0f172a;font-size:16px}
.chat-doc-meta{font-size:13px;color:#475569;margin-bottom:4px;text-transform:uppercase;letter-spacing:0.08em}
.chat-doc-answer{margin:0 0 6px;font-size:16px;line-height:1.6;color:#0f172a}
.chat-doc-citations{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.citation-chip{
  border:1px solid #cfd8ea;
  background:#fff;
  color:#0f172a;
  font-weight:600;
  padding:6px 14px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
  transition:background .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease;
  display:inline-flex;
  align-items:center;
  gap:6px;
  box-shadow:0 1px 2px rgba(15,23,42,0.08);
}
.citation-chip:hover{
  background:#eef2ff;
  border-color:#b6c4e1;
}
.citation-chip.is-active{
  background:#1d2a66;
  border-color:#1d2a66;
  color:#fff;
  box-shadow:0 3px 6px rgba(29,42,102,0.35);
}
.chat-continuity,.chat-summary,.chat-followup{margin:4px 0;font-size:16px;line-height:1.6;color:#0f172a}
.chat-summary{font-weight:400}
.chat-continuity{color:#334155;font-style:italic}
.chat-followup{color:#0f172a;font-weight:400}
.pill-row{display:flex;flex-wrap:wrap;gap:12px;margin:4px 0 8px; justify-content:flex-start}
.pill{background:#fff;border:1px solid var(--gray);padding:11px 18px;border-radius:999px;cursor:pointer;font-size:16.2px;box-shadow:0 1px 2px rgba(41, 81, 150, 0.443);transition:background .15s ease,border-color .15s ease,color .15s ease; text-decoration:none; display:inline-flex; align-items:center; gap:8px}
.pill:hover{border-color:#cbd5e1}
/* Accent pill for professional CTA look (sky blue) */
.action-pill{background:var(--sky); color:#fff !important; border-color:var(--sky)}
.action-pill:hover{background:var(--sky-2); border-color:var(--sky-2)}
/* Outline pills used for quick navigation buttons */
.pill-outline{
  background:#fff;
  color:var(--blue-2) !important;
  border:1.5px solid var(--blue-2);
  font-weight:700;
  letter-spacing:0.2px;
}
.pill-outline:hover{
  background:rgba(37,99,235,0.08);
  border-color:var(--blue);
  color:var(--blue);
}
.chat-input{display:flex;flex-direction:column;gap:10px;padding:14px 18px 16px;border-top:1px solid var(--gray);align-items:stretch;background:var(--white)}
.chat-form{display:flex;gap:10px;width:100%}
.chat-form input[type=text]{flex:1;border:1px solid var(--gray);border-radius:999px;padding:15px 22px;font-size:16px; outline:none}
.upload-disabled{border:1px dashed var(--gray);border-radius:14px;padding:14px;text-align:center;font-size:14px;color:var(--muted);background:#fafafa}
.file-chooser{display:flex;align-items:center;gap:10px;width:100%;flex-wrap:wrap}
.file-input{position:absolute;opacity:0;width:0;height:0}
.file-btn{border:1px solid var(--gray);background:#fff;color:#0f172a;border-radius:10px;padding:11px 16px;cursor:pointer;font-weight:700;font-size:15px}
.file-btn:hover{border-color:#cbd5e1}
.file-name{flex:1;min-width:0;color:#6b7280;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.primary-btn{background:var(--blue);color:#fff;border:0;border-radius:12px;padding:12px 18px;cursor:pointer;font-size:15.5px}
.primary-btn:hover{background:var(--blue-2)}
.send-btn{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--blue);color:#fff;border:0;border-radius:999px;cursor:pointer;font-size:20px}
.send-btn:hover{background:var(--blue-2)}

.section-subtitle{
  font-weight:800;
  margin:18px 0 10px;
  color:var(--brand-blue);
  letter-spacing:0.3px;
  font-size:18px;
}
.clause-standard-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.clause-standard-list li{
  border:1px solid #dbe7ff;
  border-radius:12px;
  padding:12px 14px;
  background:#f8fbff;
  color:#0f172a;
  line-height:1.4;
}
.clause-standard-list strong{
  color:var(--brand-blue);
  display:block;
  margin-bottom:4px;
}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:10px;padding:12px 16px;font-size:16px;text-decoration:none;cursor:pointer}
.btn-outline{border:1px solid var(--gray);background:#fff;color:#0f172a}
.btn-outline:hover{border-color:#cbd5e1}

/* Header Actions */
.header-actions{display:flex;align-items:center;gap:10px}

/* Links */
.link{color:var(--blue-2);text-decoration:none}

/* Small helpers */
.muted{color:var(--muted)}
.spacer-8{height:8px}
.spacer-12{height:12px}

/* Compliance mode */
.table-responsive{
  overflow:auto;
  max-height:60vh;
  border:1px solid #d5ddf1;
  border-radius:14px;
  box-shadow:0 10px 28px rgba(15,23,42,0.08);
}
.compliance-table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:15px;
  line-height:1.5;
  color:#0f172a;
  background:#f8fbff;
}
.compliance-table thead th{
  position:sticky;
  top:0;
  z-index:1;
}
.compliance-table th{
  background:#2f5eb5;
  color:#f8fbff;
  text-align:left;
  padding:14px 16px;
  font-weight:800;
  letter-spacing:0.2px;
}
.compliance-table tbody tr:nth-child(even) td{background:#f3f6ff;}
.compliance-table td{
  background:#fff;
  padding:14px 16px;
  border-bottom:1px solid #e2e8f0;
  vertical-align:top;
}
.compliance-table tr td:first-child{border-top-left-radius:10px;border-bottom-left-radius:10px;font-weight:800;color:#1e293b;}
.compliance-table tr td:last-child{border-top-right-radius:10px;border-bottom-right-radius:10px;}
.badge-ok{
  background:#e8f7ef;
  color:#0f5132;
  border:1px solid #b7e4c7;
  padding:4px 10px;
  border-radius:12px;
  font-size:12.5px;
  font-weight:800;
}
.badge-warn{
  background:#fff1f0;
  color:#b42318;
  border:1px solid #f8cfc5;
  padding:4px 10px;
  border-radius:12px;
  font-size:12.5px;
  font-weight:800;
}
