:root{font-family:Plus Jakarta Sans,Inter,Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;color:#1e293b;background:#f8fafc;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--b24-primary: #2fc6f6;--b24-primary-dark: #1a73e8;--b24-secondary: #525c69;--surface: rgba(255, 255, 255, .82);--surface-solid: #ffffff;--border: rgba(226, 232, 240, .92);--muted: #64748b;--text: #1e293b;--accent-gradient: linear-gradient(135deg, #2fc6f6 0%, #1a73e8 100%)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;background:#f8fafc;color:var(--text);font-size:13px}button,input,textarea,select{font:inherit}h1,h2,h3,h4,p{margin:0}.page{min-height:100vh}.page-placement{background:#f8fafc}.placement-shell{min-height:100vh;display:flex;flex-direction:column}.topbar{position:sticky;top:0;z-index:30;display:flex;justify-content:space-between;align-items:center;gap:20px;padding:12px 24px;background:#ffffffd1;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--border)}.topbar-main,.topbar-actions{display:flex;align-items:center;gap:14px}.document-chip{display:grid;gap:2px}.document-chip-label{font-size:10px;color:#94a3b8;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.document-chip strong{font-size:18px;line-height:1.1;color:#1f2937}.document-chip small{color:#64748b;font-size:11px}.topbar-divider{width:1px;height:32px;background:#e2e8f0}.language-switcher{display:flex;gap:4px;padding:4px;background:#f1f5f9;border-radius:10px}.language-chip{min-width:46px;border:0;border-radius:8px;padding:7px 12px;background:transparent;color:#64748b;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;cursor:pointer;box-shadow:none}.language-chip-active{background:#fff;color:#2563eb;box-shadow:0 1px 2px #0f172a14}.placement-body{flex:1;display:flex;min-height:0}.work-area{flex:1;overflow-y:auto;padding:32px}.work-stack{max-width:1120px;margin:0 auto;display:grid;gap:28px}.modern-card{background:var(--surface);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(226,232,240,.8);border-radius:12px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008;padding:24px}.section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#94a3b8}.section-dot{width:7px;height:7px;border-radius:999px;background:var(--b24-primary)}.document-header-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px 20px}.document-header-grid-compact .field:nth-child(4),.document-header-grid-compact .field:nth-child(5),.document-header-grid-compact .field:nth-child(6){align-self:end}.field{display:grid;gap:6px}.field span{font-size:11px;font-weight:600;color:#64748b}.field small{color:#94a3b8;font-size:10px;line-height:1.45}.field input,.field textarea,.field select,.group-title-input{width:100%;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 12px;color:#1e293b;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease}.field textarea{min-height:88px;resize:vertical}.field input:focus,.field textarea:focus,.field select:focus,.group-title-input:focus{outline:none;border-color:var(--b24-primary);box-shadow:0 0 0 4px #2fc6f61a}.field-full{grid-column:1 / -1}.field-search{min-width:280px}.field-compact input{text-align:center}button{border:0;border-radius:8px;padding:10px 18px;background:var(--accent-gradient);color:#fff;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,background-color .2s ease,opacity .2s ease;box-shadow:0 4px 12px #2fc6f64d}button:hover:enabled{transform:translateY(-1px);box-shadow:0 6px 15px #2fc6f666}button:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.secondary-button{background:#fff;color:#475569;border:1px solid #e2e8f0;box-shadow:none}.ghost-button{background:#f8fafc;color:#475569;border:1px solid #e2e8f0;box-shadow:none;padding:8px 12px}.danger-button{background:#fff1f2;color:#e11d48;box-shadow:none;padding:8px 12px}.inline-link-button{background:transparent;color:#0ea5e9;box-shadow:none;padding:0;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.inline-link-button:hover:enabled{transform:none;box-shadow:none;text-decoration:underline}.groups-section,.version-list{display:grid;gap:20px}.group-card{padding:0;overflow:visible}.group-toolbar{display:flex;justify-content:space-between;align-items:start;gap:18px;padding:18px 24px;border-bottom:1px solid #f1f5f9;background:#fff;border-radius:12px 12px 0 0}.group-title-wrap{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.group-accent{width:8px;height:32px;border-radius:999px;background:#3b82f6;flex:0 0 auto}.group-title-input{border:0;background:transparent;padding:0;border-radius:0;font-size:17px;font-weight:700;color:#1e293b;box-shadow:none}.group-search-panel{position:relative;width:min(100%,320px)}.search-results-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;max-height:280px;overflow-y:auto;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px #0000001a;z-index:20}.search-result-card{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px 14px;border-bottom:1px solid #f1f5f9;background:#fff}.search-result-card:last-child{border-bottom:0}.search-result-meta{display:grid;gap:2px}.search-result-meta strong{font-size:13px;color:#334155}.search-result-meta span{font-size:11px;color:#64748b}.group-meta-bar{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:12px 24px;color:#64748b;font-size:11px}.group-actions,.line-item-actions{display:flex;flex-wrap:wrap;gap:8px}.line-items-table{padding:0 0 18px}.line-items-table-header{display:grid;grid-template-columns:minmax(180px,1.15fr) minmax(180px,1.15fr) minmax(120px,.8fr) repeat(4,minmax(84px,.55fr));gap:12px;padding:10px 24px;background:#f1f5f9;color:#94a3b8;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.line-item-row-table{display:grid;grid-template-columns:minmax(180px,1.15fr) minmax(180px,1.15fr) minmax(120px,.8fr) repeat(4,minmax(84px,.55fr));gap:12px;align-items:start;padding:16px 24px;border-bottom:1px solid #f1f5f9;background:#ffffff73}.line-item-row-table:last-of-type{border-bottom:0}.line-item-sum{display:grid;gap:3px;padding-top:21px;text-align:right}.line-item-sum strong{font-size:15px;color:#0f172a}.line-item-sum span{font-size:10px;color:#94a3b8}.line-item-actions{grid-column:1 / -1;padding-top:4px}.line-item-empty{margin:16px 24px 0;padding:16px;border:1px dashed #cbd5e1;border-radius:10px;background:#f8fafc;color:#64748b}.group-card-active{box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008,0 0 0 1px #2fc6f62e}.group-totals{display:flex;flex-wrap:wrap;gap:10px;padding:0 24px 22px}.group-totals span{padding:10px 12px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:12px;font-weight:600}.details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}.details-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.summary-sidebar{width:360px;border-left:1px solid var(--border);background:#fff;display:flex;flex-direction:column;min-height:0}.summary-sidebar-scroll{flex:1;overflow-y:auto;padding:32px;display:grid;gap:28px}.summary-block h3{margin-bottom:16px;color:#94a3b8;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em}.summary-metrics{display:grid;gap:14px}.summary-row{display:flex;justify-content:space-between;gap:12px;align-items:baseline;color:#64748b}.summary-row strong{color:#334155;font-size:14px}.summary-row-total{padding-top:14px;border-top:1px solid #f1f5f9}.summary-row-total span{color:#0f172a;font-weight:700;font-size:15px}.summary-row-total strong{color:#2563eb;font-size:28px;font-weight:800;line-height:1}.summary-note{padding:18px;background:#eff6ffcc;border:1px dashed #bfdbfe;border-radius:12px}.summary-note h4{margin-bottom:10px;color:#1d4ed8;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.summary-note p{color:#1d4ed8c7;font-size:12px;line-height:1.6}.info-list{display:grid;gap:12px}.info-row{display:flex;justify-content:space-between;gap:12px;align-items:start}.info-row span{color:#64748b}.info-row strong{color:#334155;text-align:right}.status-panel{display:grid;gap:10px}.status-panel p{padding:12px;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc;color:#475569}.version-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px;border:1px solid #f1f5f9;border-radius:10px;background:#fff}.version-copy{display:grid;gap:2px}.version-copy strong{color:#334155;font-size:13px}.version-copy p{color:#94a3b8;font-size:10px}.summary-sidebar-footer{padding:24px 32px;border-top:1px solid #f1f5f9;background:#f8fafcbf}.footer-action-button{width:100%;background:#525c69;box-shadow:0 8px 18px #525c6929}.footer-action-button:hover:enabled{background:#414a54;box-shadow:0 10px 20px #525c6938}.empty-state{color:#64748b}.health-page{min-height:100vh;display:grid;place-items:center}@media(max-width:1320px){.placement-body{flex-direction:column}.summary-sidebar{width:100%;border-left:0;border-top:1px solid var(--border)}}@media(max-width:960px){.topbar,.topbar-main,.topbar-actions,.group-toolbar,.group-meta-bar,.details-grid,.document-header-grid,.details-form-grid{display:grid}.topbar,.work-area,.summary-sidebar-scroll,.summary-sidebar-footer{padding:16px}.topbar-main,.topbar-actions,.group-toolbar,.group-meta-bar{gap:12px}.topbar-divider{display:none}.field-search,.group-search-panel{width:100%}.line-items-table-header,.line-item-row-table{grid-template-columns:1fr}.line-item-sum{padding-top:0;text-align:left}.info-row,.version-item{flex-direction:column;align-items:start}.info-row strong{text-align:left}}@media(max-width:640px){.language-switcher,.group-actions,.line-item-actions,.group-totals{display:grid}.modern-card{padding:16px}.group-toolbar,.group-meta-bar,.line-items-table-header,.line-item-row-table,.group-totals{padding-left:16px;padding-right:16px}button{width:100%}}
