:root{--bg: #fdfaf3;--bg-card: #fff8ec;--bg-cream: #fff4e0;--coral: #ff9a8b;--orange: #ff9a56;--peach: #ffc371;--peach-soft: #ffe0b2;--mint: #7fd8be;--mint-soft: #c8f0e4;--mint-deep: #4ecdc4;--grad-brand: linear-gradient(90deg, #ff9a56 0%, #ffc371 35%, #7fd8be 75%, #4ecdc4 100%);--grad-warm: linear-gradient(135deg, #ff9a56, #ffb4c6);--shadow-sm: 0 2px 8px rgba(255, 154, 86, .12);--shadow-md: 0 6px 20px rgba(255, 154, 86, .18);--text: #3d2a1f;--text-soft: #7a6458;--text-muted: #a99786;--border-subtle: rgba(255, 154, 86, .18);--err: #ff6b6b;--err-bg: #ffe0e0}*{box-sizing:border-box}html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Poppins,Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.55}#app{max-width:1280px;margin:0 auto;padding:48px 40px 120px}.app-header{display:flex;flex-direction:column;gap:6px;margin-bottom:36px}.app-header h1{margin:0;font-size:32px;font-weight:800;letter-spacing:-.02em;background:var(--grad-brand);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.app-header .sub{color:var(--text-muted);font-size:13px;font-weight:600}.nav{display:flex;gap:16px;margin-top:12px;align-items:center}.nav a{color:var(--text-soft);text-decoration:none;font-weight:600;padding:8px 16px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-card);transition:all .2s ease}.nav a.active{color:#fff;background:var(--grad-warm);border-color:transparent;box-shadow:var(--shadow-sm)}.nav a:hover:not(.active){border-color:var(--peach)}.logout-btn{margin-left:auto;padding:8px 14px;border:1px solid var(--border-subtle);background:var(--bg-card);border-radius:10px;font-family:inherit;font-size:13px;font-weight:600;color:var(--text-soft);cursor:pointer;transition:all .2s ease}.logout-btn:hover{border-color:var(--err);color:var(--err)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:18px;padding:28px 32px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.card h2{margin:0 0 12px;font-size:20px;font-weight:700}.card h3{margin:20px 0 10px;font-size:15px;font-weight:700;color:var(--text-soft)}.card.center{text-align:center;max-width:480px;margin:80px auto}.card.error{border-color:var(--err);background:var(--err-bg);color:#8a2a2a}.muted{color:var(--text-soft);font-size:13px}code{background:#ffffffb3;padding:2px 6px;border-radius:6px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px}.primary{background:var(--grad-warm);color:#fff;border:none;border-radius:12px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.primary:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:2px 10px;background:var(--peach-soft);color:var(--text);border-radius:999px;font-size:12px;font-weight:700;margin-left:8px}.projects-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px;border-radius:12px;overflow:hidden;border:1px solid var(--border-subtle)}.projects-table th{text-align:left;padding:12px 14px;background:var(--peach-soft);font-weight:700;font-size:13px}.projects-table td{padding:12px 14px;border-top:1px solid var(--border-subtle);vertical-align:top}.projects-table tr:nth-child(2n) td{background:var(--bg)}.pill{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:700;background:var(--peach-soft);color:var(--text)}.pill.active{background:var(--mint-soft);color:var(--mint-deep)}.pill.dev{background:var(--peach-soft);color:var(--orange)}.code-row{display:flex;align-items:stretch;gap:8px;margin:8px 0}.code-row pre{flex:1;margin:0;background:#ffffffd9;border:1px solid var(--border-subtle);border-radius:10px;padding:10px 14px;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;white-space:pre-wrap;word-break:break-all}.copy-btn{background:linear-gradient(135deg,#7fd8be,#c8b6ff);color:#fff;border:none;border-radius:10px;padding:6px 16px;font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}.copy-btn:hover{transform:translateY(-1px)}.graph-placeholder{min-height:320px;border:1px dashed var(--border-subtle);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-top:16px}.tab-bar{display:flex;gap:4px;margin-top:16px;border-bottom:1px solid var(--border-subtle)}.tab-btn{padding:8px 18px;border:none;border-bottom:2px solid transparent;background:transparent;font-family:inherit;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;transition:all .15s ease;border-radius:6px 6px 0 0}.tab-btn:hover{color:var(--text);background:var(--bg-card)}.tab-btn.active{color:var(--text);border-bottom-color:var(--orange);background:var(--bg-card)}.tab-panel{padding-top:0}.mermaid-toolbar{display:flex;gap:8px;align-items:center;margin:12px 0}.mermaid-source{background:#fff8ec;border:1px solid var(--border-subtle);border-radius:12px;padding:16px 20px;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:12.5px;line-height:1.55;color:var(--text);white-space:pre;overflow:auto;max-height:640px;margin:0}.graph-canvas{min-height:640px;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg);margin-top:16px;overflow:hidden;position:relative}.graph-canvas svg{display:block;width:100%}.side-panel{position:absolute;right:24px;top:120px;width:280px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm);z-index:10}.side-panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.side-panel-dl{display:grid;grid-template-columns:auto 1fr;gap:4px 12px;font-size:13px;margin:0 0 12px}.side-panel-dl dt{color:var(--text-muted);font-weight:600}.side-panel-dl dd{margin:0;color:var(--text)}.side-panel-link{display:inline-block;padding:6px 12px;font-size:12px}.muted-details{margin-top:16px;font-size:13px}.muted-details summary{cursor:pointer;color:var(--text-muted);font-weight:600;padding:8px 0}.fb-row{padding:4px 0;border-bottom:1px dashed var(--border-subtle)}.fb-row:last-child{border-bottom:none}.warn-card{padding:24px;text-align:center;color:var(--text-soft);background:var(--bg-cream);border-radius:12px}.error-card{padding:24px;text-align:center;color:var(--err);background:var(--err-bg);border-radius:12px}.obsidian-canvas{background:radial-gradient(ellipse at center,#fff4e0,#f4e6c8)}.matrix-host{margin-top:16px}.matrix-wrapper{max-height:640px;overflow:auto;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-card)}.matrix-table{border-collapse:collapse;font-family:SF Mono,Menlo,Monaco,Consolas,monospace;font-size:10px;color:var(--text)}.matrix-table th,.matrix-table td{border:1px solid var(--border-subtle);padding:0;width:14px;height:14px;min-width:14px;min-height:14px;box-sizing:border-box}.matrix-table th.matrix-col{writing-mode:vertical-rl;transform:rotate(180deg);padding:4px 2px;height:auto;min-height:120px;background:var(--peach-soft);font-weight:700;vertical-align:bottom;white-space:nowrap}.matrix-table th.matrix-row{padding:2px 8px;min-width:160px;width:auto;background:var(--peach-soft);font-weight:700;text-align:right;cursor:pointer;white-space:nowrap}.matrix-table th.matrix-row:hover{color:var(--orange)}.matrix-table thead th{position:sticky;top:0;z-index:2;background:var(--peach-soft)}.matrix-table tbody th.matrix-row{position:sticky;left:0;z-index:1}.matrix-table td.cell.empty{background:transparent}.matrix-table td.cell.edge{background:var(--mint-soft)}.matrix-table td.cell.edge-parsed{background:var(--mint-deep)}.matrix-table td.cell.edge-llm{background:var(--peach);opacity:.55}.diff-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}.diff-group{background:#ffffffb3;border:1px solid var(--border-subtle);border-radius:10px;padding:12px 14px}.diff-group h4{margin:0 0 8px;font-size:14px;display:flex;align-items:center;gap:6px}.diff-group ul{margin:0;padding-left:18px;font-size:13px}.diff-group li{margin:2px 0}.badge.added{background:var(--mint-soft);color:var(--mint-deep)}.badge.removed{background:var(--peach-soft);color:var(--orange)}.badge.updated{background:#e7eaff;color:#4251a3}@media (max-width: 768px){.diff-row{grid-template-columns:1fr}}@media (max-width: 768px){#app{padding:24px 16px 80px}.app-header h1{font-size:24px}.nav{flex-wrap:wrap}}.version-badge{position:fixed;top:8px;right:160px;font-size:11px;color:#999;opacity:.6;z-index:9999;-webkit-user-select:text;user-select:text;cursor:text;pointer-events:auto;font-family:SF Mono,Monaco,Consolas,monospace}.user-info{position:fixed;top:8px;right:12px;font-size:11px;color:#999;opacity:.8;z-index:9999;-webkit-user-select:text;user-select:text;display:inline-flex;align-items:center;gap:8px}.user-signout{background:none;border:none;color:#888;font-size:11px;cursor:pointer;padding:0;text-decoration:underline;font-family:inherit}.user-signout:hover{color:#555}.dashboard-header{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:4px}.search-box{flex:1;min-width:240px;max-width:420px;padding:8px 14px;border:1px solid var(--border-subtle);border-radius:10px;background:#ffffffd9;font-family:inherit;font-size:14px;outline:none}.search-box:focus{border-color:#7fd8be;box-shadow:0 0 0 3px #7fd8be2e}.projects-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.projects-table th.sortable:hover{color:var(--text)}.sort-arrow{font-size:10px;color:#bbb;margin-left:2px}.sort-arrow.active{color:#7fa;font-weight:700}.date-col{font-variant-numeric:tabular-nums;font-family:SF Mono,Monaco,Consolas,monospace;font-size:12px;color:#666;white-space:nowrap}
