:root{color-scheme:light dark;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;padding:0;margin:0;background:radial-gradient(circle at top,#f6f8ff,#edf1f7 40%,#dfe4ef)}body{margin:0}.container{max-width:1280px;margin:0 auto;padding:32px 24px}header{text-align:center;margin-bottom:24px}header h1{margin-bottom:8px}main{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.panel{background:#ffffffed;border-radius:16px;padding:24px;box-shadow:0 24px 60px #0f214c1f;display:flex;flex-direction:column;gap:16px}label{font-weight:600}input,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(40,62,100,.15);background:#ffffffd9;font-family:inherit;resize:vertical}button{border:none;border-radius:12px;padding:13px 18px;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#1f6feb,#6c5ce7);color:#fff;transition:transform .1s ease,box-shadow .3s ease}button:disabled{opacity:.6;cursor:progress}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 18px 40px #2d54cf40}.results section{display:flex;flex-direction:column;gap:12px}pre{padding:16px;border-radius:12px;background:#0f1844eb;color:#e6ecff;overflow-x:auto}.muted{color:#273354b3;font-style:italic}.error{color:#c92a2a;background:#ffe0e0cc;padding:12px 14px;border-radius:10px}.diagram-label{margin:0;font-size:.95rem}.mermaid-container{background:#fff;border-radius:12px;padding:16px;box-shadow:inset 0 0 0 1px #18203e14;overflow:auto}.global-container{max-width:99%;margin:0 auto;padding:32px 24px}.app-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:24px}.app-nav{display:flex;gap:12px}.nav-link{padding:10px 16px;border-radius:12px;background:#ffffff80;color:#1f3c88;font-weight:600;text-decoration:none;transition:background .2s ease,color .2s ease}.nav-link:hover{background:#647cf126}.nav-link.active{background:linear-gradient(135deg,#1f6feb,#6c5ce7);color:#fff;box-shadow:0 12px 30px #4169e133}.page-container{min-height:calc(100vh - 200px)}.page-grid{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(360px,1fr))}.rag-page{align-items:start}.upload-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}.upload-item{border-radius:12px;border:1px solid rgba(40,62,100,.15);padding:12px 14px;background:#fffc}.hint{margin-top:16px;font-size:.92rem;color:#1d2c5fbf}.results-panel{display:flex;flex-direction:column;gap:16px}.ghost-button{border:1px solid rgba(31,111,235,.4);border-radius:12px;padding:10px 16px;background:#1f6feb14;color:#1f6feb;font-weight:600;cursor:pointer;transition:background .2s ease,box-shadow .2s ease}.ghost-button:hover:not(:disabled){background:#1f6feb29;box-shadow:0 10px 24px #1f6feb33}.result-body{display:flex;flex-direction:column;gap:16px}.tab-bar{display:flex;flex-wrap:wrap;gap:10px}.tab-button{border:1px solid rgba(24,32,62,.16);background:#ffffffbf;border-radius:10px;padding:9px 14px;font-weight:600;color:#18203ecc;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.tab-button.active{background:linear-gradient(135deg,#3c5de3,#7b5cf0);color:#fff;border-color:transparent;box-shadow:0 12px 34px #3c5de359}.tab-content{background:#ffffffeb;border-radius:16px;padding:20px;box-shadow:inset 0 0 0 1px #18203e14;display:grid;gap:18px}.analysis-block{background:#f4f7ffb3;border-radius:12px;padding:16px 18px;border:1px solid rgba(24,32,62,.06);display:grid;gap:12px}.results-panel{display:flex;flex-direction:column;gap:18px}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.ghost-button{border:1px solid rgba(31,111,235,.4);border-radius:12px;padding:10px 16px;background:#1f6feb14;color:#1f6feb;font-weight:600;cursor:pointer;transition:background .2s ease,box-shadow .2s ease,transform .1s ease}.ghost-button:hover:not(:disabled){background:#1f6feb29;box-shadow:0 12px 30px #1f6feb26;transform:translateY(-1px)}.ghost-button:disabled{opacity:.6;cursor:wait}.result-body{display:grid;gap:20px;scroll-margin-top:80px}.hero-card{display:grid;gap:18px;padding:24px;border-radius:22px;background:linear-gradient(135deg,#3447a61f,#895bff1f);border:1px solid rgba(48,70,170,.18);box-shadow:0 24px 60px #3046aa2e}.hero-meta h3{margin:12px 0 6px;font-size:1.6rem}.hero-meta p{margin:0;max-width:720px;color:#151f42d9;line-height:1.55}.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;background:#4461f12e;color:#2a42a5;font-weight:600;text-transform:uppercase;letter-spacing:.08em;font-size:.75rem}.summary-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.summary-card{border-radius:18px;padding:16px 18px;background:#ffffffe0;display:flex;gap:14px;align-items:center;border:1px solid rgba(32,51,112,.08);box-shadow:inset 0 0 0 1px #20337008}.icon-bubble{width:48px;height:48px;border-radius:14px;background:#3a63e01f;color:#3654ce;display:grid;place-items:center;font-size:1.4rem}.summary-value{font-size:1.5rem;font-weight:700;color:#16265ff2}.sticky-tabs{position:sticky;top:16px;z-index:9;padding:6px 0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tab-bar{display:inline-flex;flex-wrap:wrap;gap:10px;padding:8px;border-radius:16px;background:#ffffffeb;box-shadow:0 18px 45px #1a2c6324;border:1px solid rgba(26,44,99,.12)}.tab-button{border:none;padding:10px 18px;border-radius:12px;font-weight:600;color:#18203ecc;background:transparent;cursor:pointer;transition:all .2s ease}.tab-button:hover{background:#3e74e51f}.tab-button.active{background:linear-gradient(135deg,#3c5de3,#7b5cf0);color:#fff;box-shadow:0 14px 40px #3c5de359}.tab-content{display:grid;gap:20px}.architecture-layout{display:grid;gap:18px}.card{border-radius:18px;padding:20px 22px;background:#fffffff0;border:1px solid rgba(32,51,112,.09);box-shadow:0 18px 40px #2033701f;display:grid;gap:16px}.card-header{display:flex;gap:16px;align-items:center}.icon-circle{width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:#2033701f;color:#213477;font-size:1.3rem}.icon-circle.accent{background:#4cc9f040;color:#0b7285}.icon-circle.warning{background:#ffc45740;color:#a96f05}.icon-circle.neutral{background:#3f5efb26;color:#3140b1}.chip-grid{display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0;list-style:none}.chip{padding:6px 14px;border-radius:999px;font-weight:600;font-size:.92rem}.chip-primary{background:#3e74e533;color:#2d4aa1}.chip-neutral{background:#1c2c601f;color:#1c2c60d9}.card-grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.metric-card{border-radius:14px;padding:14px 16px;background:#f4f7ffcc;border:1px solid rgba(32,51,112,.08);display:flex;gap:12px}.metric-icon{font-size:1.3rem}.options-grid{display:grid;gap:12px}.option-card{border-radius:14px;padding:16px 18px;border:1px solid rgba(32,51,112,.08);background:#f8f9fff2;position:relative}.option-card.selected{border-color:#7b5cf080;box-shadow:0 18px 40px #7b5cf040;background:#7b5cf01f}.option-id{font-weight:700;color:#18203ed1}.option-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:999px;background:#3dc98e38;color:#147956;font-weight:600;font-size:.78rem}.highlight-card{border:none;background:linear-gradient(135deg,#3dc98e24,#895bff2e)}.ordered-list{margin:0;padding-left:18px;display:grid;gap:8px}.glass-table{border-radius:20px;overflow:hidden;background:#fffffff0;border:1px solid rgba(32,51,112,.09);box-shadow:0 22px 46px #20337024}.glass-table table{width:100%;border-collapse:collapse}.glass-table thead{background:linear-gradient(135deg,#1824521f,#18245214)}.glass-table th,.glass-table td{padding:14px 16px;text-align:left;border-bottom:1px solid rgba(24,36,82,.08);vertical-align:top}.glass-table tr:last-child td{border-bottom:none}.status-pill{display:inline-block;padding:6px 12px;border-radius:999px;font-weight:600;font-size:.85rem;background:#27335417;color:#273354eb}.status-pill.success{background:#2ed57333;color:#1b8a4a}.status-pill.warning{background:#ffc45740;color:#a96f05}.status-pill.info{background:#56a7ff38;color:#0f52b6}.tag{display:inline-flex;padding:5px 12px;border-radius:10px;background:#3447a61f;color:#3447a6;font-weight:600;font-size:.88rem}.tag-topic{background:#313f9c26;color:#2c3faa}.tag-uml{background:#895bff2e;color:#5630d3}.uml-grid{display:grid;gap:20px}.uml-block{border-radius:20px;padding:18px;background:#fffffff2;border:1px solid rgba(24,36,82,.08);box-shadow:0 18px 36px #1824521f}.uml-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.compact-list{list-style:none;padding:0;margin:0;display:grid;gap:4px}.centered{text-align:center}.rag-wrapper{display:grid;gap:28px}.rag-header{display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap}.rag-header h1{margin:0;font-size:1.7rem;letter-spacing:.08em;text-transform:uppercase}.rag-header p{margin:8px 0 0;color:#151f42b3;max-width:720px}.rag-actions{display:flex;align-items:center;gap:14px}.status-chip{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:12px;background:#4cc9f02e;color:#0b7285;font-weight:600}.status-chip .dot{width:10px;height:10px;border-radius:50%;background:#12b886;box-shadow:0 0 0 4px #12b8862e}.user-avatar{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:#2134761f;border:none;font-size:1.3rem;cursor:pointer;transition:background .2s ease,transform .1s ease}.user-avatar:hover{background:#21347638;transform:translateY(-1px)}.rag-quick-tabs{display:flex;gap:12px;padding:12px;border-radius:16px;background:#fffffff0;box-shadow:0 18px 44px #1a2c6329;flex-wrap:wrap}.rag-quick-tabs .tab-pill{flex:1;min-width:180px;border:none;padding:14px 18px;border-radius:12px;font-weight:600;background:transparent;color:#151f429e;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:10px}.rag-quick-tabs .tab-pill:hover:not(.active){background:#3c5de31f;color:#151f42d9}.rag-quick-tabs .tab-pill.active{background:linear-gradient(135deg,#3c5de3,#7b5cf0);color:#fff;box-shadow:0 16px 40px #3c5de347}.rag-grid{display:grid;gap:28px}.rag-upload-card{padding:26px;border-radius:24px;background:linear-gradient(135deg,#4d77ff1f,#936aff29);border:1px solid rgba(55,85,226,.18);box-shadow:0 20px 48px #3755e238}.rag-upload-card header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:24px;flex-wrap:wrap}.rag-upload-card header h2{margin:0;font-size:1.35rem}.rag-upload-card header p{margin:8px 0 0;color:#151f42ad;max-width:640px}.rag-table-card{padding:24px;border-radius:20px;background:#fffffff2;border:1px solid rgba(32,51,112,.09);box-shadow:0 22px 48px #20337029}.rag-table-card header{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.table-scroll{overflow-x:auto}.rag-table{width:100%;border-collapse:collapse;min-width:720px}.rag-table th{text-align:left;padding:12px 14px;font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;color:#1b275299;border-bottom:1px solid rgba(24,36,82,.12)}.rag-table td{padding:14px;border-bottom:1px solid rgba(24,36,82,.08);vertical-align:middle}.rag-table tbody tr:hover{background:#3f5efb14}.doc-name{display:grid;gap:4px}.doc-name strong{color:#151f42e6}.history-status{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-weight:600;font-size:.85rem}.history-status.success{background:#2ed5732e;color:#18794d}.history-status.pending{background:#ffc45733;color:#a96f05}.history-status.error{background:#ff6b6b38;color:#b21f1f}.table-actions{display:flex;gap:8px}.table-actions button{border:none;border-radius:10px;padding:6px 10px;background:#2134761a;color:#213476d1;cursor:pointer;transition:background .2s ease,transform .1s ease}.table-actions button:hover{background:#3c5de32e;transform:translateY(-1px)}.rag-placeholder{padding:52px 32px;border-radius:22px;background:#fffffff0;border:1px dashed rgba(48,70,170,.24);text-align:center;display:grid;gap:12px;color:#151f42a8}.rag-placeholder h3{margin:0;font-size:1.35rem}
