:root{--app-bg: #0b1220;--app-bg-soft: #0f1a2c;--panel-bg: linear-gradient(180deg, #1f2c42 0%, #1b273c 100%);--panel-alt-bg: #1f2937;--panel-border: #42536f;--panel-border-soft: #33465f;--text-main: #e6edf8;--text-muted: #9fb0c9;--text-soft: #c8d6ed;--primary: #4f9ef2;--primary-strong: #3b82f6;--primary-soft: rgba(79, 158, 242, .22);--success: #22c55e;--danger: #ef4444;--radius-lg: 14px;--radius-md: 10px;--radius-sm: 8px;--shadow-soft: 0 18px 38px rgba(0, 0, 0, .45);font-family:Segoe UI,Inter,Noto Sans,sans-serif;line-height:1.45;font-weight:400;color:var(--text-main);background-color:var(--app-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-height:100vh;background:radial-gradient(circle at 15% -10%,rgba(96,165,250,.17) 0%,transparent 36%),radial-gradient(circle at 85% -20%,rgba(52,211,153,.1) 0%,transparent 34%),linear-gradient(180deg,var(--app-bg-soft) 0%,var(--app-bg) 100%);color:var(--text-main)}h1,h2,h3,h4{margin:0;color:var(--text-main)}button,input,select,textarea{font:inherit}.sidebar{width:220px;height:100vh;position:fixed;top:0;left:0;background:linear-gradient(180deg,#28364e,#253349);border-right:1px solid var(--panel-border);padding:.95rem;display:flex;flex-direction:column;transform:translate(0);transition:transform .2s ease;z-index:1100;box-shadow:8px 0 22px #0000003d}.sidebar.closed{transform:translate(-100%)}.sidebar-header{margin-bottom:1.1rem;padding-bottom:.9rem;border-bottom:1px solid var(--panel-border);text-align:left}.sidebar-header h3{margin:0;font-size:1.72rem;line-height:1}.sidebar-header h3 a{color:#eef4ff;text-decoration:none;letter-spacing:-.03em;font-weight:800}.sidebar-header h3 a:hover{color:#fff}.sidebar-nav{flex:1}.sidebar-nav ul{list-style:none;padding:0;margin:0;display:grid;gap:.32rem}.sidebar-nav a{display:block;padding:.72rem .9rem;border-radius:9px;color:#d0dbed;text-decoration:none;font-size:1.04rem;font-weight:500;border:1px solid transparent;transition:background-color .18s ease,color .18s ease,border-color .18s ease}.sidebar-nav a:hover{background:#ffffff0d;border-color:#ffffff14;color:#f6f9ff}.sidebar-nav a.active{background:linear-gradient(180deg,#6f94c952,#5f81b15c);border-color:#aecbf76b;color:#fff;font-weight:700}.sidebar-overlay{position:fixed;inset:0;background:#0000007a;z-index:1000}.sidebar-bottom-actions{display:grid;gap:.45rem;margin-top:.7rem;margin-bottom:.6rem;padding-top:.6rem;border-top:1px solid var(--panel-border)}.sidebar-bottom-actions button{width:100%;border:1px solid #526584;background:#152338;color:#d9e5f9;border-radius:8px;padding:.5rem .65rem;font-weight:700;cursor:pointer;text-align:left}.sidebar-bottom-actions button:hover{background:#1d2f4a;border-color:#7aa9e8}@media(min-width:900px){.sidebar{transform:translate(0)!important}.sidebar-overlay{display:none}}.dashboard{display:flex;flex-direction:column}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(320px,.9fr);gap:1rem;align-items:start}.dashboard-right-stack{display:grid;gap:1rem;align-content:start}.dashboard-panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:1rem 1.05rem;box-shadow:inset 0 1px #ffffff08}.dashboard-panel h3{margin:0;color:var(--text-main)}.panel-header-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.8rem}.panel-header-left{display:grid;gap:.5rem}.event-filter-group{display:inline-flex;align-items:center;gap:.45rem}.event-filter{border:1px solid #455976;background:#0b1525;border-radius:999px;padding:.22rem .65rem;font-size:.8rem;font-weight:700;cursor:pointer;color:var(--text-muted)}.event-filter.finance.active{border-color:#3b82f6;background:#2563eb3d;color:#9ac7ff}.event-filter.agenda.active{border-color:#10b981;background:#10b9813d;color:#7fe6c6}.event-filter:not(.active){opacity:.6}.panel-link-button{border:1px solid #5a6f8f;background:#0f1b2f;color:#90cdf4;border-radius:10px;padding:.42rem .7rem;font-size:.88rem;font-weight:700;text-decoration:none}.panel-link-button:hover{background:#1a2a44;color:#bfdbfe}.panel-empty{margin:0;color:var(--text-muted)}.seven-days-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.55rem}.day-card{border:1px solid var(--panel-border-soft);border-radius:11px;background:linear-gradient(180deg,#0f1a2f,#0d1728);padding:.45rem;height:410px;display:flex;flex-direction:column;gap:.45rem;overflow:hidden}.day-card-head{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #32465f;padding-bottom:.3rem}.day-week{color:var(--text-muted);font-size:.78rem;text-transform:lowercase}.day-number{color:var(--text-main);font-size:.95rem}.day-empty{margin:0;color:#6f829d;font-size:.9rem}.day-events{list-style:none;margin:0;padding:0;display:grid;gap:.38rem;align-content:start}.day-events li{border:1px solid #273a56;border-radius:8px;padding:.35rem;background:#0b1525;display:grid;gap:.2rem;cursor:pointer;transition:transform .12s ease,box-shadow .12s ease}.day-events li:hover{transform:translateY(-1px);box-shadow:0 8px 18px #00000040}.day-events li.finance{border-color:#3b82f66b;background:linear-gradient(180deg,#2563eb38,#0b1525eb)}.day-events li.agenda{border-color:#10b98175;background:linear-gradient(180deg,#10b98133,#0b1525eb)}.event-main{display:grid;gap:.1rem}.event-main strong{color:var(--text-main);font-size:.82rem;line-height:1.2}.day-events b{color:#fca5a5;font-size:.8rem}.day-more-row{border:none!important;background:transparent!important;padding:0!important}.day-more-button{width:100%;border:1px solid #415671;background:#10203a;color:#9fd2ff;border-radius:8px;padding:.32rem .45rem;font-size:.78rem;font-weight:700;cursor:pointer}.day-more-button:hover{background:#162946;color:#c6e4ff}.gauge-panel{display:grid;gap:.7rem}.gauge-main{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:.9rem}.gauge-wrap{position:relative;width:170px;height:170px}.gauge{display:block}.gauge-track{stroke:#22c55e}.gauge-progress{stroke:#ef4444;stroke-linecap:round}.gauge-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center}.gauge-percent{color:var(--text-main);font-size:1.55rem;font-weight:800;line-height:1}.gauge-percent.over-limit{color:#f87171}.gauge-legend{width:100%;display:grid;grid-template-columns:1fr;gap:.45rem}.gauge-legend div{background:#0b1525;border:1px solid var(--panel-border-soft);border-radius:10px;padding:.55rem .6rem;display:grid;gap:.15rem}.gauge-legend span{color:var(--text-muted);font-size:.8rem}.gauge-legend strong{color:var(--text-main);font-size:.96rem}.category-panel{display:grid;gap:.8rem}.category-list{list-style:none;margin:0;padding:0;display:grid;gap:.7rem}.category-list li{display:grid;gap:.35rem}.category-item-clickable{cursor:pointer;border-radius:8px;padding:.2rem .15rem;transition:background-color .15s ease}.category-item-clickable:hover{background:#94a3b814}.category-item-clickable:focus-visible{outline:2px solid rgba(96,165,250,.7);outline-offset:2px}.category-row-head{display:flex;align-items:center;justify-content:space-between;gap:.7rem}.category-row-head strong{color:var(--text-main);font-size:.95rem}.category-values{display:inline-flex;align-items:baseline;gap:.35rem;color:#cbd5e0}.category-values span,.category-values b{font-size:.9rem}.category-values b{color:var(--text-muted)}.category-track{height:8px;width:100%;border-radius:999px;background:#94a3b82e;overflow:hidden}.category-fill{height:100%;border-radius:999px}.day-details-overlay,.event-details-overlay,.category-details-overlay{position:fixed;inset:0;z-index:1450;background:#00000094;display:flex;align-items:center;justify-content:center;padding:1rem}.day-details-card,.event-details-card{width:min(560px,100%);max-height:calc(100vh - 2rem);overflow:auto;background:linear-gradient(180deg,#29374f,#233149);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:.9rem}.category-details-card{width:min(560px,100%);max-height:calc(100vh - 2rem);overflow:auto;background:linear-gradient(180deg,#29374f,#233149);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:.9rem;display:grid;gap:.65rem}.day-details-header,.event-details-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.7rem;padding-bottom:.55rem;border-bottom:1px solid var(--panel-border)}.category-details-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.2rem;padding-bottom:.55rem;border-bottom:1px solid var(--panel-border)}.day-details-header h4,.event-details-header h4,.category-details-header h4{margin:0;color:var(--text-main);font-size:1.05rem}.day-details-header button,.event-details-header button,.category-details-header button{width:30px;height:30px;border:1px solid var(--panel-border);border-radius:7px;background:#111b2f;color:#d4e1f6;font-size:1.2rem;line-height:1;cursor:pointer}.category-details-total{display:flex;align-items:center;justify-content:space-between;gap:.7rem;border:1px solid #304562;background:#0b1525;border-radius:9px;padding:.5rem .6rem}.category-details-total span{color:var(--text-muted)}.category-details-total strong{color:var(--text-main)}.category-details-empty{margin:0;color:var(--text-muted)}.category-details-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.category-details-list li{border:1px solid #304562;border-radius:9px;background:#0b1525;padding:.45rem .55rem;display:grid;gap:.2rem}.category-details-row{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.category-details-row strong{color:var(--text-main)}.category-details-row b{color:#c9dbf6}.category-details-list p{margin:0;color:var(--text-muted);font-size:.84rem}.day-details-list{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}.day-details-list li{border:1px solid #273a56;border-radius:8px;padding:.42rem .5rem;background:#0b1525;display:grid;gap:.2rem;cursor:pointer}.day-details-list li:hover{box-shadow:0 8px 18px #00000040}.day-details-list li.finance{border-color:#3b82f66b;background:linear-gradient(180deg,#2563eb33,#0b1525eb)}.day-details-list li.agenda{border-color:#10b9816b;background:linear-gradient(180deg,#10b98133,#0b1525eb)}.day-details-list b{color:#fca5a5;font-size:.88rem}.event-details-line{display:flex;justify-content:space-between;gap:.8rem;margin-bottom:.55rem}.event-details-line span,.event-details-desc span{color:var(--text-muted)}.event-details-line strong{color:var(--text-main);font-weight:700}.event-details-desc{display:flex;justify-content:space-between;gap:.8rem;align-items:flex-start}.event-details-desc p{margin:0;color:var(--text-main);text-align:right}@media(max-width:1300px){.dashboard-grid{grid-template-columns:1fr}}@media(max-width:1200px){.seven-days-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:720px){.seven-days-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.panel-header-row{align-items:flex-start;flex-direction:column}.gauge-main{grid-template-columns:1fr;justify-items:center}}.finance-page{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem;align-items:start}.finance-section{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:.82rem;display:grid;grid-template-rows:auto minmax(0,1fr);gap:.62rem;min-height:272px;box-shadow:inset 0 1px #ffffff08}.finance-section-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem}.finance-section-title-wrap{display:inline-flex;align-items:baseline;gap:.7rem}.finance-section-header h2{margin:0;font-size:1.06rem;color:var(--text-main)}.finance-section-header strong{color:#8ed2ff;font-size:.95rem}.section-add-toggle{border:1px solid #5a6f8f;background:#0f1b2f;color:#90cdf4;border-radius:10px;padding:.34rem .66rem;font-size:.84rem;font-weight:700;cursor:pointer}.section-add-toggle:hover{background:#1a2a44;color:#bfdbfe}.finance-modal-overlay{position:fixed;inset:0;z-index:1500;background:#00000094;display:flex;align-items:center;justify-content:center;padding:1rem}.finance-modal-card{width:min(760px,100%);max-height:calc(100vh - 2rem);overflow:auto;background:linear-gradient(180deg,#29374f,#233149);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:.9rem;display:grid;gap:.7rem}.finance-modal-header{display:flex;align-items:center;justify-content:space-between;gap:.6rem;padding-bottom:.55rem;border-bottom:1px solid var(--panel-border)}.finance-modal-header h3{margin:0;color:var(--text-main);font-size:1.05rem}.finance-modal-header button{width:30px;height:30px;border:1px solid var(--panel-border);border-radius:7px;background:#111b2f;color:#d4e1f6;font-size:1.2rem;line-height:1;cursor:pointer}.finance-form-grid{display:grid;gap:.4rem}.finance-field{display:grid;gap:.24rem}.finance-field label{color:#a8bad5;font-size:.79rem;font-weight:700;white-space:nowrap}.finance-form-grid.income{grid-template-columns:minmax(0,1.5fr) minmax(120px,180px) auto}.finance-form-grid input,.finance-form-grid select,.recurring-modal-form .finance-field input,.recurring-modal-form .finance-field select{width:100%;padding:.52rem .62rem;border-radius:8px;border:1px solid #51627d;background:#0b1525;color:var(--text-main);box-sizing:border-box;font-size:.92rem}.finance-form-grid input:focus,.finance-form-grid select:focus,.recurring-modal-form .finance-field input:focus,.recurring-modal-form .finance-field select:focus{outline:none;border-color:#7ab3ff;box-shadow:0 0 0 2px #60a5fa33}.finance-form-grid button{border:1px solid #64a9f6;background:linear-gradient(180deg,#4f9ef2,#3b82f6);color:#fff;border-radius:8px;padding:.22rem .64rem;min-height:34px;width:92px;max-width:100%;justify-self:start;align-self:end;font-weight:700;cursor:pointer;font-size:.84rem}.finance-form-grid button:hover{filter:brightness(1.05)}.recurring-modal-form{display:grid;gap:.7rem;background:linear-gradient(180deg,#4f9ef21a,#0f172a3d);border:1px solid #4b5e7a;border-radius:12px;padding:.85rem}.recurring-modal-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.55rem}.recurring-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.recurring-modal-actions .recurring-submit,.recurring-modal-actions .recurring-cancel{width:100%;min-height:38px;border-radius:9px;font-size:.9rem;font-weight:700}.recurring-modal-actions .recurring-cancel{border:1px solid #586881;background:#0f172a73;color:#cbd5e0}.recurring-modal-actions .recurring-cancel:hover{background:#3341558c}.recurring-modal-actions .recurring-submit{border:1px solid #64a9f6;background:linear-gradient(180deg,#4f9ef2,#3b82f6);color:#fff}.recurring-modal-actions .recurring-submit:hover{filter:brightness(1.05)}.finance-list{list-style:none;margin:0;padding:0;display:grid;gap:.55rem}.finance-list-box{border:1px solid var(--panel-border-soft);background:linear-gradient(180deg,#0e1a2f,#0c172a);border-radius:11px;min-height:0;height:340px;overflow:auto;padding:.4rem;scrollbar-width:thin;scrollbar-color:#4f627f #132034}.finance-list-box::-webkit-scrollbar{width:8px}.finance-list-box::-webkit-scrollbar-track{background:#132034;border-radius:8px}.finance-list-box::-webkit-scrollbar-thumb{background:#4f627f;border-radius:8px}.finance-list-box::-webkit-scrollbar-thumb:hover{background:#6b86ad}.finance-list li{border:1px solid #304562;border-radius:9px;background:#0b1525;padding:.45rem .5rem;display:grid;gap:.3rem}.finance-list-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.6rem}.finance-list-row strong{color:var(--text-main);font-size:.92rem}.finance-list-row div{display:inline-flex;align-items:center;gap:.45rem}.finance-list-row span{color:#d2deef;white-space:nowrap}.finance-list p{margin:0;color:var(--text-muted);font-size:.82rem}.finance-list .danger{border:1px solid #7f1d1d;background:#3f1b1b;color:#fecaca;border-radius:7px;padding:.2rem .4rem;font-size:.74rem;cursor:pointer}.finance-list .danger:hover{background:#5b2121}.finance-list .edit-btn{border:1px solid #51627d;background:#1a263b;color:#e2e8f0;border-radius:7px;padding:.2rem .4rem;font-size:.74rem;cursor:pointer}.finance-list .edit-btn:hover{background:#243249}.progress-track{height:8px;border-radius:999px;background:#94a3b833;overflow:hidden}.progress-fill{height:100%;border-radius:999px}.progress-fill.income{background:linear-gradient(90deg,#22c55e,#10b981)}.progress-fill.credit{background:linear-gradient(90deg,#60a5fa,#3b82f6)}.credit-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.credit-actions span{color:#93c5fd;font-size:.83rem}@media(max-width:1300px){.finance-page{grid-template-columns:1fr}}@media(max-width:900px){.finance-form-grid.income,.recurring-modal-row{grid-template-columns:1fr}.finance-list-row,.credit-actions{flex-direction:column;align-items:flex-start}}.calendar-page{display:flex;flex-direction:column;gap:.4rem}.calendar-shell{width:100%;background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--radius-lg);padding:.7rem;box-shadow:inset 0 1px #ffffff08}.calendar-page .fc{color:var(--text-main)}.calendar-page .fc .fc-toolbar.fc-header-toolbar{margin-bottom:.45rem}.calendar-page .fc-toolbar-title{color:var(--text-main);font-size:2rem;font-weight:700}.calendar-page .fc .fc-col-header-cell{background:#22324c}.calendar-page .fc .fc-col-header-cell-cushion,.calendar-page .fc .fc-daygrid-day-number{color:var(--text-soft);text-decoration:none;font-size:.98rem}.calendar-page .fc .fc-col-header-cell-cushion{font-weight:700;padding:.45rem .2rem;text-transform:lowercase}.calendar-page .fc .fc-daygrid-day.fc-day-today{background-color:#4f9ef247}.calendar-page .fc .fc-daygrid-day-frame{min-height:108px;padding-bottom:.2rem}.calendar-page .fc .fc-daygrid-day-events{margin-bottom:0;margin-top:0}.calendar-page .fc-event{border-radius:7px;font-size:.83rem;padding:1px 3px;cursor:pointer;box-shadow:0 4px 10px #0000002e}.calendar-page .fc-button{background:#23314a;border-color:#4b607f;color:#dce8fb;font-size:.78rem;padding:.2rem .4rem;line-height:1.1;min-height:29px;border-radius:8px;font-weight:700}.calendar-page .fc .fc-button-group>.fc-button{min-width:32px}.calendar-page .fc .fc-icon{font-size:.95em}.calendar-page .fc-button:hover{background:#2b3d5d}.calendar-page .fc .fc-financeToggle-button,.calendar-page .fc .fc-agendaToggle-button{font-size:.72rem;font-weight:700;padding:.12rem .45rem;min-height:24px;line-height:1}.calendar-page .fc .fc-financeToggle-button.is-off,.calendar-page .fc .fc-agendaToggle-button.is-off{opacity:.55;background-color:#1a202c;border-color:#4a5568}.calendar-page table.fc-scrollgrid{border-color:var(--panel-border);border-radius:10px;overflow:hidden}.calendar-page .fc .fc-scroller{scrollbar-width:none;-ms-overflow-style:none}.calendar-page .fc .fc-scroller::-webkit-scrollbar{display:none}.calendar-page .fc-theme-standard td,.calendar-page .fc-theme-standard th{border-color:var(--panel-border-soft)}.calendar-page .fc .fc-daygrid-day.fc-day-disabled,.calendar-page .fc .fc-cell-shaded{background:#131f34}.calendar-page .fc-daygrid-more-link{color:#90cdf4;font-weight:700;font-size:.95rem}.calendar-page .fc-daygrid-more-link:hover{color:#bee3f8}.calendar-page .fc-popover{border:1px solid var(--panel-border);border-radius:10px;background:var(--panel-alt-bg);box-shadow:var(--shadow-soft);overflow:hidden}.calendar-page .fc-popover-header{background:#2a374c;color:var(--text-main);border-bottom:1px solid var(--panel-border);padding:.5rem .65rem}.calendar-page .fc-popover-title{font-weight:700}.calendar-page .fc-popover-close{color:#cbd5e0;opacity:1}.calendar-page .fc-popover-close:hover{color:#fff}.calendar-page .fc-popover-body{padding:.45rem;background:var(--panel-alt-bg)}.calendar-page .fc-popover .fc-daygrid-event-harness{margin:.25rem 0}.calendar-detail-overlay{position:fixed;inset:0;z-index:1400;background:#00000094;display:flex;align-items:center;justify-content:center;padding:1rem}.calendar-detail-card{width:min(460px,100%);background:linear-gradient(180deg,#29374f,#233149);border:1px solid var(--panel-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:1rem}.calendar-detail-header{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.8rem;padding-bottom:.7rem;border-bottom:1px solid var(--panel-border)}.calendar-detail-header h4{margin:0;color:var(--text-main);font-size:1.1rem}.calendar-detail-header button{width:30px;height:30px;border:1px solid var(--panel-border);border-radius:7px;background:#111b2f;color:#d4e1f6;font-size:1.2rem;line-height:1;cursor:pointer}.calendar-detail-line{display:flex;justify-content:space-between;gap:.8rem;margin-bottom:.55rem}.calendar-detail-line span,.calendar-detail-desc span{color:var(--text-muted)}.calendar-detail-line strong,.calendar-detail-desc strong{color:var(--text-main);font-weight:700;text-align:right}.calendar-detail-desc{display:flex;justify-content:space-between;gap:.8rem;align-items:flex-start}.todo-page{--todo-bg: #0f172a;--todo-panel: #1e293b;--todo-panel-soft: #223148;--todo-input: #0b1526;--todo-border: #41526d;--todo-border-soft: #31435f;--todo-text: #e6edf8;--todo-text-soft: #9fb0c9;--todo-primary: #5fa8ff;--todo-primary-strong: #3b82f6;--todo-danger: #f87171;--todo-shadow: 0 18px 38px rgba(0, 0, 0, .45);display:flex;flex-direction:column;gap:.95rem}.todo-container{display:grid;grid-template-columns:minmax(300px,370px) minmax(0,1fr);gap:1rem;align-items:stretch}.todo-left,.todo-right{min-width:0}.todo-left{display:flex;flex-direction:column;gap:.65rem}.todo-header{display:flex;align-items:center;justify-content:space-between;gap:.7rem;padding:.1rem .1rem 0}.todo-header h2{margin:0;color:var(--todo-text);font-size:1.35rem;font-weight:700;letter-spacing:.01em}.todo-header button{border:1px solid #6ea6f5;background:linear-gradient(180deg,#4f9ef2,#3c87da);color:#f8fbff;border-radius:999px;padding:.48rem .95rem;font-weight:700;font-size:.88rem;cursor:pointer;box-shadow:0 8px 16px #3b82f633}.todo-header button:hover{filter:brightness(1.06)}.todo-list-card{background:linear-gradient(180deg,#1f2c42,#1b273c);border:1px solid var(--todo-border);border-radius:14px;padding:.9rem;display:grid;grid-template-rows:auto minmax(0,1fr);gap:.65rem;min-height:625px;box-shadow:inset 0 1px #ffffff08}.todo-list-card h3{margin:0;color:var(--todo-text-soft);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase}.todo-list-card ul{list-style:none;margin:0;padding:0}.todo-list-scroll{min-height:0;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#4f627f #132034;padding-right:.15rem}.todo-list-scroll p{margin:0;color:var(--todo-text-soft)}.todo-list-scroll::-webkit-scrollbar{width:8px}.todo-list-scroll::-webkit-scrollbar-track{background:#132034;border-radius:8px}.todo-list-scroll::-webkit-scrollbar-thumb{background:#4f627f;border-radius:8px}.todo-list-scroll::-webkit-scrollbar-thumb:hover{background:#6b86ad}.todo-item{display:flex;justify-content:space-between;gap:.75rem;border:1px solid var(--todo-border-soft);border-radius:11px;padding:.62rem;background:linear-gradient(180deg,#0f1a2e,#0d1728);margin-bottom:.45rem}.todo-item:last-child{margin-bottom:0}.todo-title-wrap{display:inline-flex;align-items:center;gap:.45rem}.todo-color-dot{width:10px;height:10px;border-radius:999px;border:1px solid rgba(255,255,255,.55);flex:0 0 auto}.todo-title{color:var(--todo-text);font-weight:700;font-size:.95rem;line-height:1.2}.todo-meta{color:#95abd0;font-size:.82rem;margin-top:.22rem}.todo-desc{color:#c4d2ea;font-size:.84rem;margin-top:.2rem;line-height:1.35}.todo-actions{display:inline-flex;flex-direction:column;gap:.26rem;min-width:60px;align-items:center}.todo-actions button{width:30px;height:30px;border:1px solid var(--todo-border);border-radius:8px;background:#172337;color:#d7e2f6;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .16s ease,transform .16s ease,color .16s ease}.todo-actions button:hover{border-color:#7ab3ff;color:#e7f0ff;transform:translateY(-1px)}.todo-actions button.secondary{border-color:#7f1d1d;background:#421d24;color:#fecaca}.todo-actions button.secondary:hover{border-color:#ef4444;background:#5f1f2a}.todo-actions .btn-icon{font-size:1rem;line-height:1}.todo-right{background:linear-gradient(180deg,#1f2c42,#1b273c);border:1px solid var(--todo-border);border-radius:14px;padding:.7rem;box-shadow:inset 0 1px #ffffff08}.todo-right .fc{color:var(--todo-text)}.todo-right .fc .fc-toolbar.fc-header-toolbar{margin-bottom:.75rem;gap:.5rem;align-items:center}.todo-right .fc-toolbar-title{color:var(--todo-text);font-size:1.45rem;font-weight:700;text-transform:lowercase}.todo-right .fc-button{background:#23314a;border:1px solid #4b607f;color:#dce8fb;border-radius:8px;font-size:.79rem;font-weight:700;min-height:31px;line-height:1;padding:.3rem .55rem;box-shadow:none}.todo-right .fc-button:hover,.todo-right .fc-button:focus{background:#2b3d5d;border-color:#6f93c4}.todo-right .fc .fc-button-group>.fc-button{min-width:34px}.todo-right .fc .fc-col-header-cell{background:#22324c}.todo-right .fc .fc-col-header-cell-cushion,.todo-right .fc .fc-daygrid-day-number{color:#c8d6ed;text-decoration:none}.todo-right .fc .fc-col-header-cell-cushion{font-size:.84rem;font-weight:700;padding:.45rem .2rem;text-transform:capitalize}.todo-right .fc .fc-daygrid-day-number{font-size:.85rem;padding:.35rem .45rem}.todo-right .fc .fc-daygrid-day.fc-day-today{background:#60a5fa3b}.todo-right .fc .fc-daygrid-day-frame{min-height:128px}.todo-right .fc-event{border-radius:8px;border-width:0;font-size:.79rem;font-weight:600;padding:2px 6px;cursor:pointer;box-shadow:0 4px 10px #0003}.todo-right .fc-daygrid-more-link{color:#8ec9ff;font-weight:700}.todo-right .fc-daygrid-more-link:hover{color:#c6e4ff}.todo-right table.fc-scrollgrid{border-color:var(--todo-border);border-radius:12px;overflow:hidden}.todo-right .fc-theme-standard td,.todo-right .fc-theme-standard th{border-color:var(--todo-border-soft)}.todo-right .fc .fc-daygrid-day.fc-day-disabled,.todo-right .fc .fc-cell-shaded{background:#131f34}.todo-right .fc-popover{border:1px solid var(--todo-border);border-radius:10px;background:var(--todo-panel);box-shadow:var(--todo-shadow);overflow:hidden}.todo-right .fc-popover-header{background:var(--todo-panel-soft);color:var(--todo-text);border-bottom:1px solid var(--todo-border);padding:.5rem .65rem}.todo-right .fc-popover-body{padding:.45rem;background:var(--todo-panel)}.todo-detail-overlay,.todo-form-modal-overlay{position:fixed;inset:0;z-index:1450;background:#00000094;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:1rem}.todo-detail-card,.todo-form-modal-card{width:min(580px,100%);max-height:calc(100vh - 2rem);overflow:auto;background:linear-gradient(180deg,#2a364d,#243249);border:1px solid var(--todo-border);border-radius:14px;box-shadow:var(--todo-shadow);padding:.9rem}.todo-detail-header,.todo-form-header-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.75rem;padding-bottom:.62rem;border-bottom:1px solid var(--todo-border)}.todo-detail-header h4,.todo-form-header-row h3{margin:0;color:var(--todo-text);font-size:1.05rem}.todo-detail-header button{width:30px;height:30px;border:1px solid var(--todo-border);border-radius:7px;background:#172337;color:#d7e2f6;font-size:1.18rem;line-height:1;cursor:pointer}.todo-form-card{background:transparent;border:0;padding:0}.todo-form-card label{display:block;margin-bottom:.24rem;color:#a8bad5;font-size:.87rem;font-weight:600}.todo-form-card input{width:100%;padding:.56rem .66rem;border-radius:8px;border:1px solid #4f6079;background:var(--todo-input);color:var(--todo-text);margin-bottom:.64rem;box-sizing:border-box;font-size:.94rem}.todo-form-card input:focus{outline:none;border-color:#7ab3ff;box-shadow:0 0 0 2px #60a5fa33}.todo-date-grid{display:grid;grid-template-columns:1fr 1fr;gap:.58rem;margin-bottom:.82rem}.todo-date-field input{margin-bottom:0}.todo-form-actions{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.todo-form-actions button{border:1px solid #4f6079;border-radius:8px;padding:.54rem;font-size:.95rem;font-weight:700;cursor:pointer}.todo-form-actions button:first-child{background:linear-gradient(180deg,#4f9ef2,#3b82f6);border-color:#64a9f6;color:#f8fbff}.todo-form-actions button:first-child:hover{filter:brightness(1.06)}.todo-form-actions button.secondary{background:#1a263b;color:#dce8fb}.todo-form-actions button.secondary:hover{background:#243249}.todo-detail-line,.todo-detail-desc{display:flex;justify-content:space-between;gap:.8rem;margin-bottom:.55rem}.todo-detail-line span,.todo-detail-desc span{color:#9cb0cc}.todo-detail-line strong,.todo-detail-desc p{color:var(--todo-text);margin:0;text-align:right}.todo-color-picker-wrap{position:relative;margin-left:auto}.todo-color-current{width:26px;height:26px;border-radius:999px;border:1px solid rgba(255,255,255,.78);padding:0;cursor:pointer;box-shadow:0 0 0 2px #ffffff1f}.todo-color-presets{position:absolute;top:calc(100% + .4rem);right:0;z-index:20;display:inline-flex;align-items:center;gap:.42rem;padding:.36rem .42rem;border:1px solid var(--todo-border);border-radius:999px;background:#1d2940}.todo-color-swatch{width:20px;height:20px;border-radius:999px;border:1px solid rgba(255,255,255,.55);cursor:pointer;padding:0}.todo-color-swatch.selected{outline:2px solid #eef4ff;outline-offset:1px}.todo-color-swatch.multi{border:1px solid rgba(255,255,255,.55);background:linear-gradient(135deg,#ef4444,#f97316,#eab308,#22c55e,#06b6d4 72%,#3b82f6 88%,#a855f7)}.todo-color-hidden-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;border:0;overflow:hidden;clip:rect(0,0,0,0);clip-path:inset(50%);white-space:nowrap}@media(max-width:1280px){.todo-container{grid-template-columns:1fr}.todo-list-card{min-height:360px}}@media(max-width:760px){.todo-header{align-items:flex-start;flex-direction:column}.todo-date-grid,.todo-form-actions{grid-template-columns:1fr}.todo-right .fc-toolbar-title{font-size:1.2rem}.todo-right .fc .fc-daygrid-day-frame{min-height:92px}}.app-container{display:flex;min-height:100vh}.burger{position:fixed;top:1rem;left:1rem;width:42px;height:38px;border:1px solid var(--panel-border);border-radius:var(--radius-sm);background:#172337;display:none;flex-direction:column;justify-content:center;gap:6px;padding:8px;z-index:1200;cursor:pointer;box-shadow:0 10px 20px #00000047}.burger span{display:block;height:3px;background:#d8e4f9;border-radius:3px}.main-content{padding:.9rem 1.25rem 1.2rem;width:100%;min-height:100vh;transition:margin-left .2s ease}.main-content.shifted{margin-left:220px}.main-content.full{margin-left:0}@media(max-width:899px){.burger{display:flex}.main-content{margin-left:0!important;padding-top:3.55rem;padding-left:.85rem;padding-right:.85rem}}
