:root{--bg: #0b1020;--bg-elev: #111733;--bg-card: #151c3a;--border: #243056;--text: #e6e8ef;--text-dim: #99a0b8;--accent: #22d3ee;--accent-soft: rgba(34, 211, 238, .12);--ok: #10b981;--warn: #f59e0b;--err: #ef4444;--shadow: 0 10px 30px rgba(0, 0, 0, .35);--radius: 12px;--mono: ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;background:radial-gradient(ellipse at top,#14204a 0%,var(--bg) 60%);color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;font-size:inherit;cursor:pointer;border-radius:8px;border:1px solid var(--border);background:var(--bg-elev);color:var(--text);padding:.5rem .9rem;transition:background .15s,border-color .15s,transform .05s}button:hover:not(:disabled){background:var(--bg-card);border-color:var(--accent)}button:active:not(:disabled){transform:translateY(1px)}button:disabled{opacity:.5;cursor:not-allowed}button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button.primary{background:var(--accent);color:#06141d;border-color:var(--accent);font-weight:600}button.primary:hover:not(:disabled){background:#4eddf0}select{font-family:inherit;background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:8px;padding:.45rem .7rem}select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-shell{min-height:100vh;display:grid;grid-template-rows:auto 1fr auto}header.topbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:#0b1020b3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:10}header.topbar .brand{display:flex;align-items:center;gap:.7rem;font-weight:700;letter-spacing:.02em}header.topbar .brand .mark{width:28px;height:28px;border-radius:7px;background:linear-gradient(135deg,var(--accent),#6366f1);display:grid;place-items:center;color:#06141d;font-family:Georgia,serif;font-weight:700;font-size:18px}header.topbar .tagline{color:var(--text-dim);font-size:.85rem}main{display:grid;grid-template-columns:minmax(280px,380px) 1fr;gap:1.25rem;padding:1.5rem;max-width:1500px;width:100%;margin:0 auto}@media (max-width: 880px){main{grid-template-columns:1fr}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.1rem 1.15rem;box-shadow:var(--shadow)}.card h2{font-size:.85rem;margin:0 0 .75rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-dim)}.stack>*+*{margin-top:1rem}.dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:2rem 1rem;text-align:center;cursor:pointer;transition:border-color .15s,background .15s;outline:none}.dropzone:hover,.dropzone.active{border-color:var(--accent);background:var(--accent-soft)}.dropzone:focus-visible{border-color:var(--accent);background:var(--accent-soft)}.dropzone .big{font-size:1.05rem;font-weight:600}.dropzone .small{color:var(--text-dim);font-size:.85rem;margin-top:.4rem}.dropzone .file-name{font-family:var(--mono);margin-top:.5rem;font-size:.9rem;color:var(--accent);word-break:break-all}.template-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.template-grid label{display:block;border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;cursor:pointer;transition:border-color .15s,background .15s}.template-grid label:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}.template-grid input{margin-right:.4rem}.template-grid .desc{display:block;color:var(--text-dim);font-size:.75rem;margin-top:.15rem}.actions-row{display:flex;flex-wrap:wrap;gap:.5rem}.status-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .6rem;border-radius:999px;font-size:.75rem;background:var(--bg-elev);border:1px solid var(--border);color:var(--text-dim)}.status-pill.ok{color:var(--ok);border-color:#10b98166}.status-pill.warn{color:var(--warn);border-color:#f59e0b66}.status-pill.err{color:var(--err);border-color:#ef444466}.status-pill .dot{width:7px;height:7px;border-radius:50%;background:currentColor}.summary-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}.summary-grid .item{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:.6rem}.summary-grid .item .label{color:var(--text-dim);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.summary-grid .item .value{font-size:1.2rem;font-weight:600;margin-top:.2rem}.warnings{max-height:220px;overflow-y:auto}.warning{font-size:.85rem;padding:.4rem .55rem;border-radius:6px;background:var(--bg-elev);border-left:3px solid var(--warn);margin-bottom:.35rem}.warning.citation{border-left-color:var(--accent)}.warning.error{border-left-color:var(--err)}.warning-empty{color:var(--text-dim);font-size:.85rem}.editor-wrapper{display:flex;flex-direction:column;height:100%;min-height:60vh}.editor-wrapper .editor-shell{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex:1}.editor-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem;flex-wrap:wrap}.editor-empty{display:grid;place-items:center;height:100%;color:var(--text-dim);text-align:center;padding:2rem}.spinner{display:inline-block;width:14px;height:14px;border:2px solid transparent;border-top-color:currentColor;border-right-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}footer.footer{padding:1rem 1.5rem;border-top:1px solid var(--border);color:var(--text-dim);font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.toast{position:fixed;bottom:1.25rem;right:1.25rem;background:var(--bg-card);border:1px solid var(--border);padding:.6rem .9rem;border-radius:8px;box-shadow:var(--shadow);font-size:.85rem;z-index:50;animation:slideIn .18s ease-out}@keyframes slideIn{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}.kbd{font-family:var(--mono);font-size:.75rem;border:1px solid var(--border);border-radius:4px;padding:.05rem .35rem;background:var(--bg-elev);color:var(--text-dim)}.hint{color:var(--text-dim);font-size:.85rem}.hint a{color:var(--accent)}.topbar-right{display:flex;align-items:center;gap:.7rem}.auth-actions{display:flex;gap:.5rem}.ghost-btn,a.ghost-btn{text-decoration:none;border:1px solid var(--border);background:transparent;color:var(--text);padding:.4rem .8rem;border-radius:8px;font-size:.9rem}.ghost-btn:hover{border-color:var(--accent);color:var(--accent)}a.primary{text-decoration:none;display:inline-block;background:var(--accent);color:#06141d;border-radius:8px;padding:.45rem .85rem;font-weight:600}a.primary:hover{background:#4eddf0;text-decoration:none}.account{position:relative}.account-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.3rem .6rem .3rem .3rem;background:var(--bg-elev);border:1px solid var(--border);border-radius:999px;color:var(--text);cursor:pointer}.account-chip:hover{border-color:var(--accent)}.avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#6366f1);display:grid;place-items:center;color:#06141d;font-weight:700;font-size:.85rem}.account-email{font-size:.85rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.account-menu{position:absolute;right:0;top:calc(100% + .4rem);background:var(--bg-card);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);min-width:180px;z-index:20;padding:.3rem;display:flex;flex-direction:column}.account-menu a,.account-menu button{text-align:left;background:transparent;border:none;color:var(--text);padding:.5rem .7rem;border-radius:6px;font-size:.9rem;cursor:pointer;text-decoration:none}.account-menu a:hover,.account-menu button:hover{background:var(--bg-elev)}.brand{text-decoration:none;color:inherit}.brand:hover{text-decoration:none}.auth-shell{display:grid;place-items:center;padding:3rem 1.25rem;min-height:calc(100vh - 200px)}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.75rem;box-shadow:var(--shadow)}.auth-header{text-align:center;margin-bottom:1.25rem}.auth-header .mark{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#6366f1);display:grid;place-items:center;color:#06141d;font-family:Georgia,serif;font-weight:700;font-size:22px;margin:0 auto .9rem}.auth-header h1{font-size:1.35rem;margin:0}.auth-sub{color:var(--text-dim);font-size:.9rem;margin-top:.35rem}.oauth-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.oauth-btn{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.6rem .8rem;border:1px solid var(--border);border-radius:8px;text-decoration:none;color:var(--text);font-weight:500;background:var(--bg-elev);transition:border-color .15s,background .15s}.oauth-btn:hover{border-color:var(--accent);text-decoration:none}.oauth-btn.google .oauth-icon{background:linear-gradient(135deg,#4285f4,#34a853);color:#fff}.oauth-btn.github .oauth-icon{background:#24292f;color:#fff}.oauth-icon{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-weight:700;font-size:.8rem}.oauth-divider{display:flex;align-items:center;gap:.75rem;color:var(--text-dim);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;margin:.9rem 0}.oauth-divider:before,.oauth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:.8rem}.auth-field{display:flex;flex-direction:column;gap:.3rem}.auth-field>span{font-size:.8rem;color:var(--text-dim);font-weight:500}.auth-field>span small{color:var(--text-dim);opacity:.7}.auth-field input{background:var(--bg-elev);border:1px solid var(--border);border-radius:8px;padding:.55rem .7rem;color:var(--text);font-family:inherit;font-size:.95rem}.auth-field input:focus-visible{outline:2px solid var(--accent);outline-offset:1px;border-color:var(--accent)}.auth-submit{margin-top:.5rem;padding:.6rem .9rem;font-weight:600;text-align:center;text-decoration:none}.auth-foot{margin-top:1.25rem;text-align:center;font-size:.85rem;color:var(--text-dim)}.auth-foot a{color:var(--accent)}.dot-sep{padding:0 .45rem;opacity:.6}.history-shell{padding:1.5rem;max-width:1100px;margin:0 auto;width:100%}.history-header{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.25rem}.history-header h1{margin:0;font-size:1.4rem}.history-sub{color:var(--text-dim);font-size:.9rem;margin-top:.3rem}.history-empty{text-align:center;padding:2.5rem 1rem}.history-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.6rem}.history-row{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.9rem 1.05rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:border-color .15s}.history-row:hover{border-color:var(--accent)}.history-row-main{min-width:0;flex:1}.history-filename{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem;align-items:center;color:var(--text-dim);font-size:.82rem}.history-date{margin-left:.4rem}.history-row-actions{display:flex;gap:.4rem;flex-shrink:0}.history-row-actions button{padding:.4rem .7rem;font-size:.85rem}button.danger{border-color:#ef444466;color:var(--err)}button.danger:hover{background:#ef444414;border-color:var(--err)}.badge{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;background:var(--accent-soft);color:var(--accent);border:1px solid rgba(34,211,238,.25);font-weight:600;letter-spacing:.02em}.badge.soft{background:var(--bg-elev);color:var(--text-dim);border-color:var(--border)}.badge.warn{background:#f59e0b1a;color:var(--warn);border-color:#f59e0b66}.badge.ok{background:#10b9811a;color:var(--ok);border-color:#10b98166}.badge.err{background:#ef44441a;color:var(--err);border-color:#ef444466}@media (max-width: 720px){.history-row{flex-direction:column;align-items:stretch}.history-row-actions{justify-content:flex-end}.history-header{flex-direction:column;align-items:stretch}}
