:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}body{margin:0}@keyframes spin{to{transform:rotate(360deg)}}.spinner{vertical-align:-.15em;opacity:.85;border:2px solid;border-top-color:#0000;border-radius:50%;width:.85em;height:.85em;margin-right:.35em;animation:.6s linear infinite spin;display:inline-block}.toaster{z-index:10000;gap:.5rem;max-width:min(380px,100vw - 2rem);display:grid;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:10px;justify-content:space-between;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9rem;font-weight:500;animation:.18s toast-in;display:flex;box-shadow:0 4px 20px #0003}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.toast-success{color:#fff;background:#0f766e}.toast-error{color:#fff;background:#bf0f2f}.toast-close{color:inherit;cursor:pointer;opacity:.75;background:0 0;border:none;flex-shrink:0;padding:0;font-size:.8rem;line-height:1}.toast-close:hover{opacity:1}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}.navbar{background:var(--bg);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding:1rem 2rem;display:flex;box-shadow:0 2px 8px #00000008}.navbar .nav-left{align-items:center;gap:1.5rem;display:flex}.navbar .nav-right{align-items:center;gap:1rem;display:flex}.navbar a,.navbar button{color:var(--text);font:inherit;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .9rem;font-weight:500;text-decoration:none;transition:background .15s,color .15s}.navbar a.active,.navbar a:hover,.navbar button:hover{background:var(--accent-bg);color:var(--accent)}.navbar .user{color:var(--text-h);margin-right:.7rem;font-size:.97rem}.btn,.btn-primary,.btn-danger{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:.55rem 1.2rem;font-size:1rem;font-weight:600;transition:background .15s,color .15s,border .15s;display:inline-block}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent-border)}.btn-primary:hover{background:#7c22c9}.btn-danger{color:#fff;background:#bf0f2f;border-color:#bf0f2f}.btn-danger:hover{background:#a10c24}.link{color:#0f766e;font-weight:600;text-decoration:none;transition:color .15s}.link:hover{color:var(--accent);text-decoration:underline}.container{text-align:left;width:min(1100px,94%);margin:2rem auto 3rem}.header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.header h2{margin:0}.header p{color:var(--text);margin-top:.5rem}.dashboard{text-align:left;width:min(1060px,92%);margin:2rem auto 3rem}.dashboard-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem;display:flex}.dashboard-header h2{margin:0}.dashboard-header p{color:var(--text);margin-top:.5rem}.projects-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;display:grid}.project-card{border:1px solid var(--border);background:color-mix(in srgb, var(--bg) 96%, #f9ece7 4%);border-radius:14px;grid-template-rows:auto 1fr;gap:.85rem;min-height:160px;padding:1rem;display:grid;box-shadow:0 8px 24px #00000014}.project-card-head{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.project-card-head-right{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.icon-btn{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:6px;padding:.15rem .25rem;font-size:.85rem;line-height:1;transition:opacity .15s}.project-card h3{color:var(--text-h);margin:0;font-size:1.1rem}.project-card p{color:var(--text);line-height:1.45}.status-chip{text-transform:uppercase;letter-spacing:.03em;border:1px solid #0000;border-radius:999px;padding:.2rem .65rem;font-size:.75rem}.status-active{color:#0a6a39;background:#eaf9f0;border-color:#9ad4b4}.status-on-hold{color:#9a5b00;background:#fff7e8;border-color:#efcd8a}.status-completed{color:#1f4f92;background:#eaf4ff;border-color:#9ebce6}.dashboard-state{border:1px dashed var(--border);color:var(--text);border-radius:12px;padding:1rem}.modal-card h3{margin-top:0;margin-bottom:1rem}.project-form input,.project-form textarea,.project-form select{border:1px solid var(--border);font:inherit;background:color-mix(in srgb, var(--bg) 96%, #fff 4%);color:var(--text-h);border-radius:10px;padding:.65rem .75rem}@media (width<=700px){.dashboard{width:min(1060px,95%)}.dashboard-header{flex-direction:column;align-items:stretch}.modal-actions{flex-direction:column-reverse}.primary-btn,.ghost-btn{width:100%}}.project-page{text-align:left;width:min(1160px,94%);margin:1.5rem auto 3rem}.project-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.2rem;display:flex}.project-header h2{margin:.35rem 0}.project-header p{color:var(--text);margin:0}.back-link{color:#0f766e;font-weight:600;text-decoration:none}.back-link:hover{text-decoration:underline}.project-status{text-transform:uppercase;letter-spacing:.05em;border:1px solid var(--border);border-radius:999px;padding:.35rem .7rem;font-size:.78rem}.project-state{border:1px dashed var(--border);border-radius:12px;padding:.85rem}.error{color:#bf0f2f}.kanban-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;display:grid}.kanban-column{border:1px solid var(--border);background:color-mix(in srgb, var(--bg) 94%, #f5efe6 6%);border-radius:14px;grid-template-rows:auto 1fr;min-height:460px;display:grid}.kanban-column>header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.9rem;display:flex}.kanban-column h3{margin:0;font-size:1rem}.kanban-column header span{border:1px solid var(--border);border-radius:999px;padding:.1rem .45rem;font-size:.8rem}.kanban-list{align-content:start;gap:.75rem;padding:.8rem;display:grid}.empty-column{border:1px dashed var(--border);border-radius:10px;margin:0;padding:.7rem}.task-card{border:1px solid var(--border);background:var(--bg);border-radius:12px;gap:.45rem;padding:.7rem;display:grid}.task-card-head{justify-content:space-between;align-items:flex-start;gap:.4rem;display:flex}.task-card h4{color:var(--text-h);margin:0;font-size:.97rem}.task-card p{color:var(--text);margin:0;line-height:1.4}.task-card small{color:var(--text);font-size:.78rem}.task-actions{flex-wrap:wrap;gap:.4rem;display:flex}.task-actions button{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:999px;padding:.2rem .6rem;font-size:.75rem}.task-actions button:hover{border-color:#0f766e}.task-actions button:disabled{opacity:.65;cursor:not-allowed}.icon-btn{cursor:pointer;opacity:.55;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:.15rem .25rem;font-size:.82rem;line-height:1;transition:opacity .15s}.icon-btn:hover{opacity:1}.icon-btn-danger:hover{opacity:1;color:#bf0f2f}.danger-btn{cursor:pointer;color:#fff;background:#bf0f2f;border:1px solid #0000;border-radius:10px;padding:.62rem 1rem;font-weight:600;transition:transform .12s,box-shadow .12s}.danger-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px #00000026}.danger-btn:disabled{opacity:.7;cursor:not-allowed}.project-header-right{flex-shrink:0;align-items:center;gap:.75rem;display:flex}.modal-overlay{z-index:999;background:#00000073;place-items:center;padding:1rem;display:grid;position:fixed;inset:0}.modal-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;width:min(560px,100%);padding:1.2rem;box-shadow:0 24px 60px #00000042}.modal-card h3{margin-top:0}.project-form{gap:.5rem;display:grid}.project-form input,.project-form textarea,.project-form select{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-h);box-sizing:border-box;border-radius:8px;padding:.55rem .7rem;font-size:.95rem}.project-form input:focus,.project-form textarea:focus,.project-form select:focus{outline-offset:1px;outline:2px solid #0f766e}.modal-actions{justify-content:flex-end;gap:.6rem;margin-top:.4rem;display:flex}.primary-btn,.ghost-btn{cursor:pointer;border:1px solid #0000;border-radius:10px;padding:.62rem 1rem;font-weight:600;transition:transform .12s,box-shadow .12s}.primary-btn{color:#fff;background:#0f766e}.primary-btn:hover,.ghost-btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px #00000026}.primary-btn:disabled{opacity:.7;cursor:not-allowed}.ghost-btn{color:var(--text-h);border-color:var(--border);background:0 0}.form-error{color:#bf0f2f;margin:0}@media (width<=1024px){.kanban-grid{grid-template-columns:1fr}.project-header{flex-direction:column}}.counter{color:var(--accent);background:var(--accent-bg);border:2px solid #0000;border-radius:5px;margin-bottom:24px;padding:5px 10px;font-size:16px;transition:border-color .3s}.counter:hover{border-color:var(--accent-border)}.counter:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.hero{position:relative}.hero .base,.hero .framework,.hero .vite{margin:0 auto;inset-inline:0}.hero .base{z-index:0;width:170px;position:relative}.hero .framework,.hero .vite{position:absolute}.hero .framework{z-index:1;height:28px;top:34px;transform:perspective(2000px)rotate(300deg)rotateX(44deg)rotateY(39deg)scale(1.4)}.hero .vite{z-index:0;width:auto;height:26px;top:107px;transform:perspective(2000px)rotate(300deg)rotateX(40deg)rotateY(39deg)scale(.8)}#center{flex-direction:column;flex-grow:1;place-content:center;place-items:center;gap:25px;display:flex}@media (width<=1024px){#center{gap:18px;padding:32px 20px 24px}}#next-steps{border-top:1px solid var(--border);text-align:left;display:flex}#next-steps>div{flex:1 1 0;padding:32px}@media (width<=1024px){#next-steps>div{padding:24px 20px}}#next-steps .icon{width:22px;height:22px;margin-bottom:16px}@media (width<=1024px){#next-steps{text-align:center;flex-direction:column}}#docs{border-right:1px solid var(--border)}@media (width<=1024px){#docs{border-right:none;border-bottom:1px solid var(--border)}}#next-steps ul{gap:8px;margin:32px 0 0;padding:0;list-style:none;display:flex}#next-steps ul .logo{height:18px}#next-steps ul a{color:var(--text-h);background:var(--social-bg);border-radius:6px;align-items:center;gap:8px;padding:6px 12px;font-size:16px;text-decoration:none;transition:box-shadow .3s;display:flex}#next-steps ul a:hover{box-shadow:var(--shadow)}#next-steps ul a .button-icon{width:18px;height:18px}@media (width<=1024px){#next-steps ul{flex-wrap:wrap;justify-content:center;margin-top:20px}#next-steps ul li{flex:calc(50% - 8px)}#next-steps ul a{box-sizing:border-box;justify-content:center;width:100%}}#spacer{border-top:1px solid var(--border);height:88px}@media (width<=1024px){#spacer{height:48px}}.ticks{width:100%;position:relative}.ticks:before,.ticks:after{content:"";border:5px solid #0000;position:absolute;top:-4.5px}.ticks:before{border-left-color:var(--border);left:0}.ticks:after{border-right-color:var(--border);right:0}
