:root{--bg:#050816;--bg-elevated:#020617;--bg-elevated-soft:#020617;--border-subtle:#1e293b;--border-strong:#334155;--text-primary:#e5e7eb;--text-secondary:#9ca3af;--accent:#22c55e;--accent-soft:#22c55e1f;--accent-strong:#16a34a;--danger:#f97373;--danger-soft:#f871711f;--muted:#6b7280;--shadow-soft:0 18px 40px #0f172acc, 0 0 0 1px #0f172acc;--sans:system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;font:16px/1.5 var(--sans);color:var(--text-primary);text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:radial-gradient(circle at top,#0f172a 0,#020617 35% 100%)}*,:before,:after{box-sizing:border-box}body{background:0 0;min-height:100vh;margin:0}#root{min-height:100vh}.app{min-height:100vh;color:var(--text-primary);grid-template-columns:260px minmax(0,1fr);display:grid}.sidebar{border-right:1px solid var(--border-subtle);background:radial-gradient(circle at top,#020617 0 40%,#020617 100%);flex-direction:column;gap:24px;padding:24px 18px 18px;display:flex}.sidebar__logo{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:13px;font-weight:600}.sidebar__nav{flex-direction:column;gap:4px;display:flex}.nav-item{all:unset;cursor:pointer;color:var(--text-secondary);border-radius:999px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;transition:background .15s,color .15s,transform .1s;display:flex}.nav-item:hover{color:var(--text-primary);background:#0f172ae6}.nav-item--active{background:var(--accent-soft);color:var(--accent)}.main{background:radial-gradient(circle at 0 0,#0f172a 0,#020617 45% 100%);flex-direction:column;gap:20px;padding:20px 24px 28px;display:flex}.main__header{justify-content:space-between;align-items:center;gap:16px;display:flex}.mobile-nav{gap:8px;margin-bottom:8px;padding-bottom:8px;display:none;overflow-x:auto}.main__subtitle{color:var(--text-secondary);margin:4px 0 0;font-size:14px}.primary-btn{all:unset;cursor:pointer;background:linear-gradient(135deg, var(--accent-strong), var(--accent));color:#0b1120;border-radius:999px;padding:8px 16px;font-size:14px;font-weight:500;transition:transform 80ms ease-out,box-shadow 80ms ease-out,filter 80ms ease-out;box-shadow:0 14px 30px #16a34a99,0 0 0 1px #0f172ae6}.primary-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.primary-btn:active{transform:translateY(0);box-shadow:0 8px 18px #16a34a80,0 0 0 1px #0f172ae6}.grid{grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:minmax(0,auto);align-items:flex-start;gap:16px;display:grid}.card{border:1px solid var(--border-subtle);box-shadow:var(--shadow-soft);background:radial-gradient(circle at 0 0,#0b1120 0,#020617 55% 100%);border-radius:18px;padding:16px 16px 14px}.card h2{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:0 0 10px;font-size:15px;font-weight:500}.card--wide{grid-column:1/-1}.list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.list-item{background:#0f172ae6;border:1px solid #1e40af1a;border-radius:12px;justify-content:space-between;align-items:center;gap:10px;padding:8px 10px;display:flex}.list-item--column{flex-direction:column;align-items:flex-start}.list-item__title{color:var(--text-primary);font-size:14px}.list-item__meta{color:var(--text-secondary);margin-top:2px;font-size:12px}.list-item__actions{align-items:center;gap:6px;display:flex}.muted{color:var(--muted);font-size:13px}.badge{text-transform:uppercase;letter-spacing:.08em;border:1px solid #0000;border-radius:999px;padding:2px 10px;font-size:11px}.badge--high{color:#fecaca;background:#f871711f;border-color:#f87171cc}.badge--medium{color:#facc15;background:#eab3081f;border-color:#eab308cc}.badge--low{color:#7dd3fc;background:#38bdf81f;border-color:#38bdf8cc}.subtasks{flex-direction:column;gap:4px;margin:8px 0 0;padding:0;list-style:none;display:flex}.subtasks__item{color:var(--text-secondary);justify-content:space-between;align-items:center;gap:8px;font-size:13px;display:flex}.budget-summary{gap:12px;margin-bottom:10px;display:flex}.budget-summary__item{background:#0f172ae6;border:1px solid #1e40af33;border-radius:12px;flex-direction:column;flex:1;gap:2px;padding:8px 10px;display:flex}.label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:11px}.value{font-size:14px}.value--income{color:#4ade80}.value--expense{color:#f97373}.value--balance{color:var(--text-primary)}.amount{font-family:var(--mono);border-radius:999px;padding:2px 8px;font-size:13px}.amount--income{color:#bbf7d0;background:#22c55e1f}.amount--expense{color:#fecaca;background:#f871711f}.form{flex-direction:column;gap:8px;display:flex}.form-row{flex-wrap:wrap;gap:8px;display:flex}.input{border:1px solid var(--border-subtle);color:var(--text-primary);background:#0f172ae6;border-radius:999px;flex:1;min-width:0;padding:8px 12px;font-size:13px}.input--sm{max-width:180px}.input--xs{max-width:150px}.input--textarea{resize:vertical;border-radius:14px;width:100%;min-height:60px;font-family:inherit}.input::placeholder{color:var(--muted)}.icon-btn{all:unset;cursor:pointer;border:1px solid var(--border-subtle);background:#0f172ae6;border-radius:999px;padding:2px 6px;font-size:13px}.icon-btn--danger{color:#fecaca;border-color:#f8717199}.card__header-row{justify-content:space-between;align-items:center;gap:8px;display:flex}.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;display:grid}.calendar-cell{border:1px solid var(--border-subtle);background:#0f172ae6;border-radius:14px;min-height:80px;padding:8px 10px}.calendar-cell--today{border-color:var(--accent)}.calendar-cell__header{justify-content:space-between;align-items:baseline;margin-bottom:4px;display:flex}.calendar-cell__dow{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:11px}.calendar-cell__day{color:var(--text-primary);font-size:13px}.calendar-cell__empty{font-size:12px}.calendar-cell__list{flex-direction:column;gap:2px;margin:4px 0 0;padding:0;list-style:none;display:flex}.calendar-cell__item{justify-content:space-between;align-items:center;gap:4px;display:flex}.calendar-cell__title{color:var(--text-secondary);font-size:12px}.dot{border-radius:999px;width:6px;height:6px}.dot--high{background:#f97373}.dot--medium{background:#facc15}.dot--low{background:#38bdf8}.gantt{flex-direction:column;gap:6px;display:flex}.gantt-row{grid-template-columns:200px minmax(0,1fr);align-items:center;gap:8px;display:grid}.gantt-row__label{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.gantt-row__track{border:1px dashed var(--border-subtle);background:#0f172ae6;border-radius:999px;height:18px;position:relative;overflow:hidden}.gantt-bar{white-space:nowrap;border-radius:999px;justify-content:center;align-items:center;font-size:10px;display:flex;position:absolute;top:1px;bottom:1px}.gantt-bar--high{background:#f87171cc}.gantt-bar--medium{background:#eab308cc}.gantt-bar--low{background:#38bdf8cc}.mini-chart{grid-template-columns:repeat(7,minmax(0,1fr));align-items:end;gap:8px;height:96px;display:grid}.mini-chart__col{flex-direction:column;align-items:center;gap:6px;display:flex}.mini-chart__bar{background:linear-gradient(180deg, var(--accent), #22c55e33);border:1px solid #22c55e59;border-radius:999px;width:100%;max-width:18px;min-height:6px}.mini-chart__label{color:var(--muted);text-transform:uppercase;font-size:10px}.progress{border:1px solid var(--border-subtle);background:#0f172ae6;border-radius:999px;width:100%;height:8px;margin-top:8px;overflow:hidden}.progress__bar{background:linear-gradient(90deg,#eab308cc,#f87171cc);height:100%}.budget-cat-row{justify-content:space-between;align-items:baseline;gap:10px;width:100%;display:flex}.modal-overlay{z-index:1000;background:#020617b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{border:1px solid var(--border-subtle);width:min(560px,100%);box-shadow:var(--shadow-soft);background:radial-gradient(circle at 0 0,#0b1120 0,#020617 55% 100%);border-radius:16px;padding:16px}.task-link{color:inherit;font:inherit;cursor:pointer;text-align:left;background:0 0;border:0;padding:0}.task-link:hover{color:#8db6ff}.task-link--small{font-size:13px}.task-details{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 14px;margin:10px 0;display:grid}@media (width<=900px){.app{grid-template-columns:minmax(0,1fr)}.sidebar{display:none}.mobile-nav{display:flex}.mobile-nav .nav-item{white-space:nowrap}.main{padding:16px}.grid{grid-template-columns:minmax(0,1fr)}}
