body{background:#0f0c1a}.app-loading{color:#a78bfa;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100vh;font-size:15px;display:flex}.spinner{border:3px solid #7c3aed33;border-top-color:#7c3aed;border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-screen{background:radial-gradient(at 50% 40%,#7c3aed1f 0%,#0000 65%),#0f0c1a;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.auth-card{text-align:center;background:#1a1530;border:1px solid #7c3aed4d;border-radius:20px;width:100%;max-width:420px;padding:48px 40px;box-shadow:0 32px 80px #00000080,0 0 0 1px #7c3aed1a}.auth-logo{background:linear-gradient(135deg,#c4b5fd,#818cf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:16px;font-size:36px}.auth-title{color:#e2e8f0;background:linear-gradient(135deg,#c4b5fd,#818cf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:8px;font-size:26px;font-weight:700}.auth-subtitle{color:#64748b;margin-bottom:36px;font-size:15px}.auth-form{text-align:left;flex-direction:column;gap:16px;display:flex}.auth-form label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.auth-form input{color:#e2e8f0;background:#ffffff0d;border:1px solid #7c3aed40;border-radius:8px;outline:none;padding:12px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.auth-form input:focus{border-color:#7c3aedb3;box-shadow:0 0 0 3px #7c3aed26}.auth-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;border-radius:10px;margin-top:4px;padding:13px 20px;font-size:15px;font-weight:700;transition:opacity .2s,transform .1s;box-shadow:0 0 20px #7c3aed59}.auth-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-hint{text-align:center;color:#475569;margin-top:-4px;font-size:12px}.auth-error{color:#f87171;font-size:13px}.auth-success{color:#34d399;font-size:13px}.google-btn{color:#1f1f1f;cursor:pointer;background:#fff;border:none;border-radius:10px;justify-content:center;align-items:center;gap:10px;width:100%;margin-bottom:4px;padding:12px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .2s;display:flex}.google-btn:hover:not(:disabled){opacity:.92}.google-btn:disabled{opacity:.5;cursor:not-allowed}.google-icon{flex-shrink:0;width:20px;height:20px}.auth-divider{color:#334155;align-items:center;gap:12px;margin:16px 0;font-size:13px;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:#ffffff14;flex:1;height:1px}.auth-tabs{background:#ffffff0a;border-radius:8px;margin-bottom:16px;padding:3px;display:flex}.auth-tab{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;flex:1;padding:7px;font-family:inherit;font-size:13px;font-weight:600;transition:all .15s}.auth-tab.active{color:#e2e8f0;background:#7c3aed4d}.auth-sent{flex-direction:column;align-items:center;gap:12px;display:flex}.auth-sent-icon{font-size:40px}.auth-sent h2{color:#e2e8f0;font-size:20px}.auth-sent p{color:#94a3b8;font-size:14px;line-height:1.6}.auth-sent strong{color:#c4b5fd}.auth-resend{color:#7c3aed;cursor:pointer;background:0 0;border:none;margin-top:8px;font-size:13px;text-decoration:underline}.header-right{align-items:center;gap:12px;display:flex}.user-email{color:#64748b;font-size:13px}.signout-btn{color:#94a3b8;cursor:pointer;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;padding:8px 14px;font-size:13px;transition:background .2s}.signout-btn:hover{background:#ffffff1f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#e2e8f0;background:#0f0c1a;min-height:100vh;font-family:system-ui,-apple-system,sans-serif}#root{border:none;width:100%;max-width:100%}.app{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-header{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f0c1ae6;border-bottom:1px solid #7c3aed40;flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 36px;display:flex}.app-header h1{letter-spacing:-.5px;color:#e2e8f0;background:linear-gradient(135deg,#c4b5fd,#818cf8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:22px;font-weight:600}.add-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s,transform .1s;box-shadow:0 0 16px #7c3aed66}.add-btn:hover{opacity:.9;transform:translateY(-1px)}.add-btn:active{transform:translateY(0)}.app-main{flex:1;position:relative;overflow:hidden}.filter-bar{background:#0f0c1acc;border-bottom:1px solid #7c3aed1f;flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:10px 36px;display:flex}.filter-pill{color:#64748b;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:20px;align-items:center;gap:6px;padding:5px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.filter-pill:hover{color:#94a3b8;background:#ffffff17}.filter-pill.active{font-weight:600}.filter-pill-all.active{color:#e2e8f0;background:#ffffff1a;border-color:#ffffff4d}.filter-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.filter-count{opacity:.6;margin-left:2px;font-size:11px}.timeline-container{background:radial-gradient(at 50% 60%,#7c3aed14 0%,#0000 70%),#0f0c1a;width:100%;height:100%;position:relative;overflow:hidden}.timeline-svg{cursor:grab;width:100%;height:100%;display:block}.timeline-svg:active{cursor:grabbing}.timeline-hint{color:#94a3b880;pointer-events:none;letter-spacing:.5px;font-size:12px;position:absolute;bottom:20px;left:50%;transform:translate(-50%)}.timeline-tooltip{pointer-events:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#141024f2;border:1px solid #7c3aed66;border-radius:10px;max-width:220px;padding:12px 16px;position:absolute;box-shadow:0 8px 32px #00000080,0 0 0 1px #7c3aed1a}.tooltip-title{color:#e2e8f0;margin-bottom:4px;font-size:14px;font-weight:700}.tooltip-date{color:#a78bfa;margin-bottom:6px;font-size:12px}.tooltip-note{color:#94a3b8;font-size:12px;line-height:1.5}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#1a1530;border:1px solid #7c3aed59;border-radius:16px;width:420px;max-width:90vw;padding:36px;position:relative;box-shadow:0 24px 64px #0009,0 0 0 1px #7c3aed1a}.modal h2{color:#e2e8f0;margin-bottom:24px;font-size:20px;font-weight:700}.modal-close{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 8px;font-size:16px;transition:color .2s;position:absolute;top:16px;right:16px}.modal-close:hover{color:#e2e8f0}.modal form{flex-direction:column;gap:16px;display:flex}.modal label{color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;flex-direction:column;gap:6px;font-size:13px;font-weight:600;display:flex}.optional{text-transform:none;color:#475569;font-size:12px;font-weight:400}.modal input,.modal textarea{color:#e2e8f0;background:#ffffff0d;border:1px solid #7c3aed40;border-radius:8px;outline:none;padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .2s}.modal input:focus,.modal textarea:focus{border-color:#7c3aedb3;box-shadow:0 0 0 3px #7c3aed26}.modal input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6)}.form-error{color:#f87171;margin-top:-4px;font-size:13px}.modal-actions{justify-content:space-between;align-items:center;gap:10px;margin-top:8px;display:flex}.modal-actions-right{gap:10px;margin-left:auto;display:flex}.btn-primary{color:#fff;cursor:pointer;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:opacity .2s}.btn-primary:hover{opacity:.9}.btn-secondary{color:#94a3b8;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1a;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s}.btn-secondary:hover{background:#ffffff1f}.btn-danger{color:#f87171;cursor:pointer;background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:background .2s,border-color .2s}.btn-danger:hover{background:#ef444438;border-color:#ef444499}.tooltip-duration{color:#64748b;align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.tooltip-duration-badge{color:#a78bfa;background:#7c3aed33;border-radius:10px;padding:1px 6px;font-size:11px;font-weight:600}.duration-toggle{color:#64748b;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:5;background:#0f0c1acc;border:1px solid #ffffff1a;border-radius:10px;align-items:center;gap:7px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s;display:flex;position:absolute;top:16px;right:16px}.duration-toggle:hover{color:#94a3b8;border-color:#fff3}.duration-toggle.active{color:#a78bfa;background:#7c3aed1f;border-color:#7c3aed66}.duration-toggle-bar{opacity:.6;background:currentColor;border-radius:3px;width:16px;height:6px;display:inline-block}.date-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.duration-preview{color:#a78bfa;align-items:center;gap:8px;margin-top:-8px;font-size:12px;display:flex}.current-badge{color:#a78bfa;background:#7c3aed33;border-radius:10px;padding:1px 7px;font-size:11px;font-weight:600}.end-date-header{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.current-checkbox{color:#a78bfa;cursor:pointer;align-items:center;gap:5px;font-size:12px;font-weight:500;text-transform:none!important;letter-spacing:0!important;flex-direction:row!important;display:flex!important}.current-checkbox input[type=checkbox]{accent-color:#7c3aed;cursor:pointer;width:14px;height:14px;box-shadow:none;background:0 0;border:none;padding:0}input[type=date]:disabled{opacity:.35;cursor:not-allowed}.tooltip-hint{color:#64748b;border-top:1px solid #ffffff0f;margin-top:6px;padding-top:6px;font-size:11px}.tooltip-category{text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:5px;margin-bottom:5px;font-size:11px;font-weight:600;display:flex}.tooltip-cat-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.timeline-legend{pointer-events:none;flex-wrap:wrap;justify-content:center;gap:16px;display:flex;position:absolute;bottom:44px;left:50%;transform:translate(-50%)}.legend-item{color:#94a3b8;align-items:center;gap:6px;font-size:12px;display:flex}.legend-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px}.category-picker{flex-wrap:wrap;gap:8px;display:flex}.category-option{color:#94a3b8;cursor:pointer;background:#ffffff0a;border:1px solid #ffffff1f;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:flex}.category-option:hover{background:#ffffff17}.category-option.selected{font-weight:600}.category-dot-sm{border-radius:50%;flex-shrink:0;width:8px;height:8px}.modal-wide{width:560px;max-height:80vh;overflow-y:auto}.category-list{flex-direction:column;gap:8px;min-height:20px;margin-bottom:28px;display:flex}.category-empty{color:#475569;text-align:center;padding:12px 0;font-size:14px}.category-row{background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.category-row-left{align-items:center;gap:10px;display:flex}.category-row-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.category-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.category-name{color:#e2e8f0;font-size:14px;font-weight:500}.category-name-input{color:#e2e8f0;background:#ffffff12;border:1px solid #7c3aed66;border-radius:6px;outline:none;width:160px;padding:6px 10px;font-family:inherit;font-size:14px}.category-add-section{border-top:1px solid #ffffff12;padding-top:20px}.category-add-section h3{color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;font-size:13px;font-weight:600}.category-add-form{flex-direction:column;gap:12px;display:flex}.color-palette{flex-wrap:wrap;gap:7px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:22px;height:22px;padding:0;transition:transform .1s,border-color .15s}.color-swatch:hover{transform:scale(1.2)}.color-swatch.selected{border-color:#fff;transform:scale(1.15)}.btn-sm{padding:5px 12px!important;font-size:12px!important}.header-btn{padding:8px 14px;font-size:13px}
