@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;1,400&display=swap";:root{--font: "Plus Jakarta Sans", system-ui, sans-serif;--bg-deep: #0a0e1a;--bg-mid: #111827;--accent: #3b82f6;--accent-soft: rgba(59, 130, 246, .35);--accent-glow: rgba(96, 165, 250, .45);--text: #f1f5f9;--text-muted: #94a3b8;--glass-bg: rgba(255, 255, 255, .06);--glass-border: rgba(255, 255, 255, .12);--glass-highlight: rgba(255, 255, 255, .08);--danger-bg: rgba(239, 68, 68, .12);--danger-text: #fecaca;--ok-bg: rgba(34, 197, 94, .12);--ok-text: #bbf7d0;--radius-lg: 20px;--radius-md: 12px;--shadow-deep: 0 24px 80px rgba(0, 0, 0, .45)}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;background:var(--bg-deep)}body{margin:0;min-height:100vh;font-family:var(--font);color:var(--text);background:var(--bg-deep);-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app-shell{position:relative;min-height:100vh;overflow-x:hidden}.app-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(ellipse 100% 80% at 50% -20%,rgba(59,130,246,.22),transparent 55%),radial-gradient(ellipse 70% 50% at 100% 50%,rgba(139,92,246,.12),transparent 50%),radial-gradient(ellipse 60% 40% at 0% 80%,rgba(14,165,233,.1),transparent 45%),linear-gradient(165deg,var(--bg-deep) 0%,var(--bg-mid) 50%,#0c1222 100%)}.app-glow{position:fixed;border-radius:50%;filter:blur(80px);opacity:.5;pointer-events:none;z-index:0;animation:float-glow 18s ease-in-out infinite}.app-glow-1{width:min(520px,90vw);height:min(520px,90vw);top:-8%;right:-10%;background:var(--accent-glow)}.app-glow-2{width:min(400px,70vw);height:min(400px,70vw);bottom:-5%;left:-15%;background:#a78bfa59;animation-delay:-7s}@keyframes float-glow{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-20px,16px) scale(1.05)}}@keyframes fade-up{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fade-up .55s ease forwards}.fade-in-delay{animation:fade-up .65s ease .08s forwards;opacity:0}.glass-panel{position:relative;z-index:1;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-deep),inset 0 1px 0 var(--glass-highlight)}.glass-card{position:relative;z-index:1;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-deep),inset 0 1px 0 var(--glass-highlight);padding:2rem;max-width:26rem;width:calc(100% - 2rem);margin:0 auto}.auth-center{position:relative;z-index:1;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.brand-lockup{text-align:center;margin-bottom:1.75rem}.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:14px;font-weight:700;font-size:1rem;letter-spacing:-.02em;background:linear-gradient(135deg,#3b82f680,#8b5cf673);border:1px solid rgba(255,255,255,.2);margin-bottom:1rem;box-shadow:0 8px 32px var(--accent-soft)}.brand-lockup h1{margin:0;font-size:1.65rem;font-weight:700;letter-spacing:-.03em}.brand-lockup .tagline{margin:.5rem 0 0;color:var(--text-muted);font-size:.9rem;line-height:1.45}.muted{color:var(--text-muted);font-size:.9rem}.muted.small{font-size:.78rem;line-height:1.5;margin-top:.35rem}.muted code{font-size:.85em;padding:.1em .35em;border-radius:4px;background:#00000040}.err{color:var(--danger-text);background:var(--danger-bg);border:1px solid rgba(248,113,113,.25);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.88rem;line-height:1.45}.info{color:var(--ok-text);background:var(--ok-bg);border:1px solid rgba(74,222,128,.2);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.88rem;line-height:1.45}.setup-callout{margin:0 1.25rem 1.25rem;padding:1.25rem 1.5rem;max-width:56rem;margin-left:auto;margin-right:auto}.setup-callout h3{margin:0 0 .5rem;font-size:1.05rem}.setup-callout p{margin:0 0 .75rem;color:var(--text-muted);font-size:.9rem}.setup-callout pre{margin:0;padding:.85rem 1rem;border-radius:10px;background:#00000059;border:1px solid var(--glass-border);font-size:.72rem;line-height:1.5;overflow-x:auto;color:#e2e8f0}.form{display:flex;flex-direction:column;gap:.75rem}.form label{display:flex;flex-direction:column;gap:.35rem;font-size:.78rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.form input,.inline input{padding:.65rem .85rem;border-radius:10px;border:1px solid var(--glass-border);background:#00000040;color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form input::placeholder,.inline input::placeholder{color:#64748b}.form input:focus,.inline input:focus{outline:none;border-color:#3b82f68c;box-shadow:0 0 0 3px #3b82f626}.row{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.25rem}.btn{font-family:inherit;font-size:.9rem;font-weight:600;padding:.55rem 1.1rem;border-radius:10px;cursor:pointer;border:1px solid transparent;transition:transform .15s ease,box-shadow .2s,background .2s}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 20px #2563eb59}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 28px #2563eb73}.btn-secondary{background:#ffffff14;color:var(--text);border-color:var(--glass-border)}.btn-secondary:hover:not(:disabled){background:#ffffff1f}.btn-ghost{background:transparent;color:var(--text-muted);border-color:var(--glass-border)}.btn-ghost:hover:not(:disabled){color:var(--text);background:#ffffff0f}button.linkish{margin-top:.15rem;align-self:center;font-size:.82rem;border:none;background:transparent;color:#93c5fd;text-decoration:underline;text-underline-offset:3px;padding:.35rem;cursor:pointer;font-family:inherit}button.linkish:hover:not(:disabled){color:#bfdbfe}button.linkish:disabled{color:#64748b}.dashboard-wrap{position:relative;z-index:1;max-width:min(96rem,100%);margin:0 auto;padding:1.25rem 1.25rem 3rem}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.35rem;margin-bottom:1.25rem}.top-bar-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.dev-pill{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;padding:.35rem .65rem;border-radius:999px;background:#eab3081f;color:#fde047;border:1px solid rgba(234,179,8,.35);white-space:nowrap}.error-boundary-fallback{min-height:100vh;margin:0;padding:2rem 1.5rem;font-family:var(--font);background:var(--bg-deep);color:var(--text)}.error-boundary-fallback h1{margin:0 0 .75rem;font-size:1.25rem}.error-boundary-fallback p{margin:0 0 1rem;color:var(--text-muted);max-width:40rem;line-height:1.5}.error-boundary-fallback pre{margin:0;padding:1rem;border-radius:var(--radius-md);background:#00000059;border:1px solid var(--glass-border);color:var(--danger-text);font-size:.85rem;white-space:pre-wrap;word-break:break-word}.brand-row{display:flex;align-items:center;gap:.85rem}.brand-row .brand-mark{margin:0;width:2.5rem;height:2.5rem;font-size:.85rem}.brand-text strong{display:block;font-size:1.1rem;letter-spacing:-.02em}.brand-sub{font-size:.75rem;color:var(--text-muted)}.dashboard-grid{display:grid;grid-template-columns:minmax(0,280px) 1fr;gap:1.25rem;align-items:start}@media(max-width:840px){.dashboard-grid{grid-template-columns:1fr}}.sidebar{padding:1.15rem 1.1rem}.sidebar h2{margin:0 0 .85rem;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.step-pill{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:.65rem}.step-pill span{display:inline-flex;align-items:center;justify-content:center;width:1.35rem;height:1.35rem;border-radius:6px;background:#3b82f633;color:#93c5fd;font-size:.65rem}.main-area{padding:1.25rem 1.35rem;min-height:12rem}.main-area h2{margin:0 0 1rem;font-size:1.05rem;font-weight:600}.inline{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.list{list-style:none;padding:0;margin:0}.list li{margin:.35rem 0}.list button{text-align:left;width:100%;font-family:inherit;font-size:.9rem;padding:.65rem .85rem;border-radius:10px;border:1px solid var(--glass-border);background:#00000026;color:var(--text);cursor:pointer;transition:background .2s,border-color .2s,transform .15s}.list button:hover{background:#ffffff0f;border-color:#ffffff2e}.list button.active{border-color:#3b82f68c;background:#3b82f61f;box-shadow:0 0 0 1px #3b82f633}.empty-hint{color:var(--text-muted);font-size:.88rem;margin:.5rem 0 0;line-height:1.5}.records{font-size:.82rem;list-style:none;padding:0;margin:0}.records li{padding:.5rem 0;border-bottom:1px solid var(--glass-border)}.records li:last-child{border-bottom:none}.records code{font-size:.75rem;color:#cbd5e1}.hr-soft{height:1px;background:var(--glass-border);margin:1rem 0;border:none}.glass-panel-inner{background:#0000001f;border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:inset 0 1px #ffffff0a}.records-header{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1rem}.records-header h2{margin:0 0 .25rem}.view-tabs{display:inline-flex;padding:.2rem;border-radius:12px;background:#0003;border:1px solid var(--glass-border);gap:.15rem}.view-tab{font-family:inherit;font-size:.82rem;font-weight:600;padding:.45rem .9rem;border-radius:9px;border:1px solid transparent;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .2s,color .2s,border-color .2s}.view-tab:hover{color:var(--text);background:#ffffff0f}.view-tab-active{color:var(--text);background:#3b82f633;border-color:#3b82f659}.records-view-body{min-height:280px}.getting-started-callout{margin:0 0 1.25rem;padding:1rem 1.15rem;border-radius:var(--radius-md);border:1px solid rgba(59,130,246,.35);background:#3b82f614}.getting-started-callout p{margin:0 0 .85rem;line-height:1.5;font-size:.92rem}.step-checklist{margin:0;padding-left:1.35rem;line-height:1.65;font-size:.9rem;color:var(--text-muted)}.step-checklist li{margin-bottom:.5rem}.step-checklist li strong{color:var(--text)}.step-checklist .step-done{color:#86efac}.step-checklist .step-done strong{color:#bbf7d0}.kanban-board{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.85rem;align-items:start}@media(max-width:900px){.kanban-board{grid-template-columns:1fr}}.kanban-column{display:flex;flex-direction:column;min-height:200px;padding:.75rem .65rem}.kanban-col-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.65rem;padding:0 .15rem}.kanban-col-head h3{margin:0;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.kanban-count{font-size:.72rem;font-weight:600;color:var(--text-muted);background:#ffffff0f;padding:.15rem .45rem;border-radius:999px}.kanban-drop{flex:1;min-height:120px;padding:.35rem;border-radius:10px;border:1px dashed transparent;transition:border-color .2s,background .2s}.kanban-drop-active{border-color:#3b82f673;background:#3b82f60f}.kanban-card{padding:.65rem .75rem;margin-bottom:.45rem;border-radius:10px;background:#ffffff0f;border:1px solid var(--glass-border);cursor:grab;transition:box-shadow .2s,transform .15s}.kanban-card:active{cursor:grabbing}.kanban-card-drag{box-shadow:0 12px 40px #00000059;border-color:#3b82f666}.kanban-card-title{display:block;font-size:.88rem;font-weight:600;line-height:1.35}.kanban-card-meta{display:block;margin-top:.35rem;font-size:.72rem;color:var(--text-muted)}.kanban-add{margin-top:.5rem;width:100%;justify-content:center}.gantt-root{display:flex;flex-direction:column;gap:.65rem}.gantt-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.65rem .85rem}.gantt-hint{font-size:.78rem;color:var(--text-muted);line-height:1.45}.gantt-hint kbd{font-family:ui-monospace,monospace;font-size:.7em;padding:.1em .35em;border-radius:4px;background:#00000059;border:1px solid var(--glass-border)}.gantt-range{font-size:.75rem;color:var(--text-muted);white-space:nowrap}.gantt-scroll{overflow-x:auto;overflow-y:hidden;padding-bottom:.5rem;border-radius:var(--radius-md);border:1px solid var(--glass-border);background:#00000026}.gantt-ruler{position:relative;height:2rem;border-bottom:1px solid var(--glass-border);background:#0003}.gantt-tick{position:absolute;top:0;bottom:0;width:1px;transform:translate(-50%);background:#ffffff1f}.gantt-tick span{position:absolute;top:.35rem;left:.35rem;font-size:.68rem;color:var(--text-muted);white-space:nowrap}.gantt-track{position:relative;min-width:100%;padding:.5rem 0}.gantt-today{position:absolute;top:0;bottom:0;width:2px;margin-left:-1px;background:#f87171d9;z-index:1;pointer-events:none;box-shadow:0 0 12px #f8717166}.gantt-row{display:grid;grid-template-columns:minmax(120px,18%) 1fr;gap:.5rem;align-items:center;padding:.35rem .65rem;min-height:2.5rem}.gantt-row-label{font-size:.8rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}.gantt-row-track{position:relative;height:2rem;border-radius:8px;background:#ffffff0a}.gantt-bar-wrap{position:absolute;top:.2rem;bottom:.2rem;display:flex;align-items:stretch;min-width:4px}.gantt-bar{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;border-radius:6px;background:linear-gradient(135deg,#3b82f68c,#2563eba6);border:1px solid rgba(147,197,253,.35);cursor:grab;touch-action:none}.gantt-bar:active{cursor:grabbing}.gantt-bar-text{font-size:.65rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.35);pointer-events:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 .25rem}.gantt-handle{flex:0 0 10px;min-width:10px;padding:0;margin:0;border:none;border-radius:4px;background:#fff3;cursor:ew-resize;touch-action:none}.gantt-handle:hover{background:#ffffff59}.gantt-handle-l{margin-right:1px}.gantt-handle-r{margin-left:1px}.gantt-empty{padding:1.5rem 1rem;text-align:center}.table-wrap{overflow-x:auto;padding:.75rem;border-radius:var(--radius-md)}.records-table{width:100%;border-collapse:collapse;font-size:.85rem}.records-table th,.records-table td{text-align:left;padding:.55rem .65rem;border-bottom:1px solid var(--glass-border);vertical-align:middle}.records-table th{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.table-title-btn{font-family:inherit;font-size:inherit;background:none;border:none;color:var(--text);cursor:pointer;text-align:left;padding:.25rem 0;text-decoration:underline;text-underline-offset:3px;text-decoration-color:#94a3b880}.table-title-btn:hover{color:#93c5fd}.table-input{width:100%;min-width:8rem;padding:.4rem .5rem;border-radius:8px;border:1px solid var(--glass-border);background:#00000040;color:var(--text);font-family:inherit;font-size:inherit}.table-select{padding:.4rem .5rem;border-radius:8px;border:1px solid var(--glass-border);background:#00000040;color:var(--text);font-family:inherit;font-size:.82rem;cursor:pointer}.table-del{font-size:.78rem;padding:.35rem .6rem}
