body,html{background:#fff;padding:0 env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}#root,body,html{height:100%}@media (prefers-color-scheme:dark){body,html{background:#121212;color:#e6e6e6}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root[data-theme=light],body[data-theme=light],html[data-theme=light]{background:#fff;color:#000}:root[data-theme=dark],body[data-theme=dark],html[data-theme=dark]{background:#121212;color:#e6e6e6}.timeline-container{overflow:visible;position:relative;width:100%}.calendar-timeline-svg{display:block;overflow:visible}.timeline-point-event:hover circle[r="5"]{r:7;filter:drop-shadow(0 0 4px rgba(0,0,0,.3))}.timeline-period-arc:hover path[stroke-width="2.5"]{stroke-width:3.5;filter:drop-shadow(0 0 4px rgba(0,0,0,.2))}.timeline-tooltip{--tooltip-arrow-color:#0a0f1eed;align-items:flex-start;animation:tooltip-appear .15s ease-out;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#0a0f1eed;border:1px solid #6366f147;border-radius:10px;box-shadow:0 12px 40px #0000008c,0 0 0 1px #ffffff0f;color:#e2e8f0;display:flex;font-size:.82rem;gap:8px;margin-top:-8px;padding:10px 13px;pointer-events:none;position:absolute;transform:translate(-50%,-100%);white-space:nowrap;z-index:100}.timeline-tooltip:after{border:6px solid #0000;border-top:6px solid var(--tooltip-arrow-color);content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.timeline-tooltip-dot{border-radius:50%;box-shadow:0 0 5px 1px currentColor;flex-shrink:0;height:9px;margin-top:2px;opacity:.9;width:9px}.timeline-tooltip-title{font-weight:600;line-height:1.3}.timeline-tooltip-date{font-size:.78rem;margin-top:2px;opacity:.6}.calendar-zoomable{overflow:auto;scrollbar-color:#6366f166 #ffffff0a;scrollbar-width:thin;touch-action:pan-x pan-y pinch-zoom}.calendar-zoomable::-webkit-scrollbar{height:6px;width:6px}.calendar-zoomable::-webkit-scrollbar-track{background:#ffffff0a;border-radius:3px}.calendar-zoomable::-webkit-scrollbar-thumb{background:#6366f166;border-radius:3px}.calendar-zoomable::-webkit-scrollbar-thumb:hover{background:#6366f1a6}.calendar-zoomable::-webkit-scrollbar-corner{background:#0000}.calendar-zoomable.is-panning,.calendar-zoomable.is-panning *{cursor:grabbing!important}.calendar-weeks-outer{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto 30px;max-width:1400px;padding:20px 16px;position:relative;width:100%}.calendar-weeks-layout{grid-column-gap:2px;grid-row-gap:2px;column-gap:2px;display:grid;grid-auto-rows:minmax(10px,1fr);grid-template-columns:40px repeat(52,minmax(10px,1fr));min-width:100%;row-gap:2px;width:-webkit-fit-content;width:fit-content}.calendar-week-label{align-items:center;color:#888;display:flex;font-size:10px;justify-content:center;padding:2px}.calendar-year-label-week{align-items:center;color:#888;display:flex;font-size:12px;font-weight:400;justify-content:flex-end;padding-right:8px}.calendar-year-label-week.decade-label{color:#2d7ff9;font-size:14px;font-weight:700}.decade-spacer{background:#0000;height:12px}.calendar-weeks-layout .calendar-cell{aspect-ratio:1/1;box-sizing:border-box;min-height:10px;min-width:10px;width:100%}.calendar-months-outer{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto 30px;max-width:1400px;padding:20px 16px;position:relative;width:100%}.calendar-months-layout{grid-column-gap:2px;grid-row-gap:2px;column-gap:2px;display:grid;grid-auto-rows:minmax(10px,1fr);min-width:100%;row-gap:2px;width:-webkit-fit-content;width:fit-content}.calendar-months-cols-1{grid-template-columns:40px repeat(12,minmax(10px,1fr))}.calendar-months-cols-2{grid-template-columns:40px repeat(12,minmax(10px,1fr)) 16px 40px repeat(12,minmax(10px,1fr))}.calendar-months-cols-5{grid-template-columns:40px repeat(12,minmax(10px,1fr)) 16px 40px repeat(12,minmax(10px,1fr)) 16px 40px repeat(12,minmax(10px,1fr)) 16px 40px repeat(12,minmax(10px,1fr)) 16px 40px repeat(12,minmax(10px,1fr))}.calendar-column-spacer{background:#0000}.calendar-month-label{align-items:center;color:#888;display:flex;font-size:10px;justify-content:center;padding:2px}.calendar-year-label-month{align-items:flex-end;color:#888;display:flex;flex-direction:column;font-size:12px;font-weight:400;gap:2px;justify-content:center;padding-right:8px;position:relative}.year-label-event-indicators{display:flex;flex-wrap:wrap;gap:2px;justify-content:flex-end}@keyframes tooltip-appear{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}@keyframes cell-tooltip-appear{0%{opacity:0;transform:translateX(-50%) translateY(calc(-100% + 5px))}to{opacity:1;transform:translateX(-50%) translateY(-100%)}}.year-label-tooltip{animation:tooltip-appear .15s ease-out;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#0a0f1eeb;border:1px solid #6366f147;border-radius:10px;bottom:calc(100% + 10px);box-shadow:0 12px 40px #0000008c,0 0 0 1px #ffffff12;color:#e2e8f0;display:none;font-size:.8rem;min-width:160px;padding:10px 13px;pointer-events:none;position:absolute;right:0;white-space:nowrap;z-index:100}.year-label-tooltip:before{border:7px solid #0000;border-top-color:#6366f14d;content:"";position:absolute;right:11px;top:100%}.year-label-tooltip:after{border:6px solid #0000;border-top-color:#0a0f1eeb;content:"";position:absolute;right:12px;top:100%}.year-label-tooltip-item{align-items:center;border-bottom:1px solid #ffffff0f;display:flex;gap:8px;letter-spacing:.01em;line-height:1.4;padding:5px 0}.year-label-tooltip-item:first-child{padding-top:2px}.year-label-tooltip-item:last-child{border-bottom:none;padding-bottom:2px}.year-label-tooltip-dot{border-radius:50%;box-shadow:0 0 5px 1px currentColor;flex-shrink:0;height:8px;opacity:.9;width:8px}.calendar-year-label-month.has-year-events:hover .year-label-tooltip{display:block}.calendar-year-label-month.decade-label{color:#2d7ff9;font-size:14px;font-weight:700}.calendar-months-layout .calendar-cell{aspect-ratio:1/1;box-sizing:border-box;min-height:10px;min-width:10px;width:100%}.calendar-years-outer{-webkit-overflow-scrolling:touch;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto 30px;max-width:1400px;padding:20px 16px;position:relative;width:100%}.calendar-years-layout{grid-column-gap:2px;grid-row-gap:2px;column-gap:2px;display:grid;grid-auto-rows:minmax(10px,1fr);min-width:100%;row-gap:2px;width:-webkit-fit-content;width:fit-content}.calendar-years-cols-1{grid-template-columns:40px repeat(10,minmax(10px,1fr))}.calendar-years-cols-2{grid-template-columns:40px repeat(10,minmax(10px,1fr)) 16px 40px repeat(10,minmax(10px,1fr))}.calendar-year-label-small{align-items:center;color:#888;display:flex;font-size:10px;justify-content:center;padding:2px}.calendar-decade-label{align-items:center;color:#2d7ff9;display:flex;font-size:14px;font-weight:700;justify-content:flex-end;padding-right:8px}.calendar-years-layout .calendar-cell{aspect-ratio:1/1;box-sizing:border-box;min-height:10px;min-width:10px;width:100%}.calendar-days-container{padding:30px;width:100%}.calendar-days-navigation{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-bottom:30px}.nav-section{align-items:center;display:flex;gap:10px}.nav-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:all .2s ease}.nav-btn:hover{background:#5568d3;transform:translateY(-1px)}.nav-select{background:#0000;border:2px solid #e5e7eb;border-radius:6px;color:inherit;cursor:pointer;font-size:1rem;font-weight:600;padding:8px 12px}.nav-select:focus{border-color:#667eea;outline:none}.nav-today-btn{background:#3f51b5;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:8px 24px;transition:all .2s ease}.nav-today-btn:hover{background:#002984;transform:translateY(-1px)}.calendar-days-with-arrows{align-items:flex-start;display:flex;gap:10px;justify-content:center;margin-top:40px;width:100%}.week-arrow-btn{align-items:center;background:#667eea;border:none;border-radius:50%;box-shadow:0 2px 8px #667eea4d;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:1.2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.week-arrow-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:scale(1.1)}.week-arrow-btn:active{transform:scale(.95)}.calendar-days-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(7,1fr);max-width:500px;width:100%}.calendar-day-header{color:#667eea;font-size:.9rem;font-weight:700;padding:10px;text-align:center}.calendar-day-cell{align-items:center;aspect-ratio:1;border-radius:6px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:50px;position:relative;transition:all .2s ease}.calendar-day-cell:hover{box-shadow:0 4px 12px #00000026;transform:scale(1.05)}.calendar-day-cell.lived{background:#3f51b5}.calendar-day-cell.remaining{background:#6b7280}.day-number{color:#fff;font-size:1.2rem;font-weight:700}.day-tooltip{animation:tooltip-appear .15s ease-out;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);background:#0a0f1eeb;border:1px solid #6366f147;border-radius:10px;bottom:calc(100% + 10px);box-shadow:0 12px 40px #0000008c,0 0 0 1px #ffffff12;color:#e2e8f0;display:none;font-size:.8rem;left:50%;line-height:1.6;min-width:120px;padding:9px 13px;position:absolute;text-align:center;transform:translateX(-50%);white-space:pre-line;z-index:10}.calendar-day-cell:hover .day-tooltip{display:block}.calendar-page{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.calendar-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;justify-content:space-between;margin-bottom:20px;padding:20px}.calendar-header h1{color:#667eea;font-size:1.8rem;margin:0}.header-actions{display:flex;gap:10px}.btn-add-event,.btn-edit,.btn-logout{border:none;border-radius:8px;cursor:pointer;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-add-event{background:linear-gradient(135deg,#3f51b5,#002984);color:#fff}.btn-add-event:hover{box-shadow:0 4px 12px #3f51b566;transform:translateY(-2px)}.btn-edit{background:#667eea;color:#fff}.btn-edit:hover{background:#5568d3}.btn-logout{background:#ef4444;color:#fff}.btn-logout:hover{background:#dc2626}.date-editor{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin:0 auto;max-width:500px;padding:40px}.date-form{display:flex;flex-direction:column;gap:15px}.date-form label{color:#374151;font-size:1rem;font-weight:600}.date-form input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:12px 16px}.date-form input:focus{border-color:#667eea;outline:none}.scale-selector{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:30px}.scale-btn{background:#fff3;border:2px solid #fff;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:10px 24px;transition:all .3s ease}.scale-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.scale-btn.active{background:#fff;color:#667eea}.events-list{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;margin-bottom:30px;padding:24px}.events-list h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:1.3rem;margin:0 0 20px}.events-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.event-card{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-radius:10px;cursor:pointer;padding:16px;position:relative;transition:all .2s ease}.event-card:hover{background:linear-gradient(135deg,#e5e7eb,#d1d5db);box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.event-card-header{align-items:center;display:flex;gap:10px;margin-bottom:8px}.event-color-badge{border:2px solid #fff;border-radius:50%;box-shadow:0 1px 3px #0003;flex-shrink:0;height:12px;width:12px}.event-title{color:#1f2937;flex:1 1;font-size:1rem;font-weight:600}.event-date{color:#6b7280;font-size:.9rem;margin-bottom:10px;padding-left:22px}.event-actions{display:flex;gap:8px;padding-left:22px}.event-action-btn{border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;padding:4px 10px;transition:all .2s ease}.event-action-btn.edit{background:#667eea;color:#fff}.event-action-btn.edit:hover{background:#5568d3}.event-action-btn.delete{background:#ef4444;color:#fff}.event-action-btn.delete:hover{background:#dc2626}.calendar-info{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px}.info-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;display:flex;flex-direction:column;padding:20px}.info-label{color:#6b7280;font-size:.9rem;font-weight:600;margin-bottom:8px;text-align:center}.info-value{color:#667eea;font-size:1.4rem;font-weight:700;text-align:center;word-break:break-word}.info-icon-wrapper{display:inline-block;margin-left:6px;position:relative}.info-icon{color:#667eea;cursor:help;display:inline-block;font-size:.9rem;font-weight:600;opacity:.7;transition:opacity .2s}.info-icon:hover{opacity:1}.info-tooltip{background:#1f2937;border-radius:6px;bottom:100%;box-shadow:0 4px 12px #00000026;color:#fff;font-size:.8rem;font-weight:400;margin-bottom:8px;max-width:250px;opacity:0;padding:10px 12px;text-align:center;transition:opacity .2s,visibility .2s;visibility:hidden;white-space:normal;width:-webkit-max-content;width:max-content;z-index:1000}.info-tooltip,.info-tooltip:after{left:50%;position:absolute;transform:translateX(-50%)}.info-tooltip:after{border:6px solid #0000;border-top-color:#1f2937;content:"";top:100%}.info-icon-wrapper:hover .info-tooltip{opacity:1;visibility:visible}.calendar-legend{display:flex;gap:30px;justify-content:center;margin-bottom:20px}.legend-item{align-items:center;color:#fff;display:flex;font-weight:600;gap:10px}.legend-color{border:2px solid #fff;border-radius:4px;height:24px;width:24px}.legend-color.lived{background:#3f51b5}.legend-color.remaining{background:#ffffff4d}.calendar-grid{grid-gap:4px;border-radius:12px;display:grid;gap:4px;margin-bottom:30px;max-width:100%;overflow:auto;padding:30px}.calendar-cell{aspect-ratio:1;border-radius:2px;cursor:pointer;min-height:8px;min-width:8px;transition:all .2s ease}.calendar-grid.compact .calendar-cell{max-height:12px;max-width:12px;min-height:5px;min-width:5px}@media (max-width:768px){.calendar-grid.compact .calendar-cell{max-height:8px;max-width:8px;min-height:3px;min-width:3px}}.calendar-cell.lived{background:#3f51b5}.calendar-cell.remaining{background:#6b7280}.calendar-cell{position:relative}@media (hover:hover){.calendar-cell:hover{box-shadow:0 2px 8px #0003;transform:scale(1.2);z-index:10}}.event-indicators{bottom:2px;display:flex;gap:2px;left:50%;position:absolute;transform:translateX(-50%);z-index:5}.event-indicator{border:1px solid #fff;border-radius:50%;box-shadow:0 1px 2px #0000004d;height:6px;width:6px}.event-count-badge{background:#00000073;border-radius:4px;color:#fff;font-size:8px;font-weight:700;line-height:1.4;padding:0 2px;white-space:nowrap}@media (max-width:768px){.event-indicator{border:.5px solid #fff;height:4px;width:4px}}.goal-indicators{display:flex;gap:1px;justify-content:center;left:50%;pointer-events:none;position:absolute;top:1px;transform:translateX(-50%);z-index:4}.goal-indicator{background-color:#f59e0b;border:.5px solid #fff;flex-shrink:0;height:5px;transform:rotate(45deg);width:5px}.goal-indicator.overdue{background-color:#ef4444!important}.goal-indicator.missed{background-color:#9ca3af!important;opacity:.6}.loading{color:#fff;font-size:1.2rem;padding:40px;text-align:center}@media (max-width:768px){.calendar-page{padding:10px}.calendar-header{flex-direction:column;gap:15px}.calendar-header h1{font-size:1.5rem}.header-actions{flex-wrap:wrap;justify-content:center}.events-list{padding:16px}.events-list h3{font-size:1.1rem}.events-grid{grid-template-columns:1fr}.calendar-info{grid-template-columns:repeat(2,1fr)}.scale-selector{gap:8px}.scale-btn{font-size:.9rem;padding:8px 16px}.calendar-grid{gap:1px;padding:10px}.calendar-cell{min-height:4px;min-width:4px}.calendar-weeks-outer{padding:10px 8px}.calendar-weeks-layout{--cell:calc(1.92308vw - 1.67308px);column-gap:1px;grid-auto-rows:var(--cell);grid-template-columns:20px repeat(52,var(--cell));min-width:0;min-width:auto;row-gap:1px;width:100%}.calendar-weeks-layout .calendar-cell{min-height:0;min-height:auto;min-width:0;min-width:auto;overflow:hidden}.calendar-weeks-layout .decade-spacer{overflow:hidden}.calendar-weeks-layout .calendar-year-label-week:not(.decade-label){font-size:0}.calendar-weeks-layout .calendar-year-label-week.decade-label{font-size:8px;overflow:visible;position:relative;z-index:1}.calendar-week-label{font-size:8px;padding:1px}.calendar-week-label.hide-mobile{font-size:0;visibility:hidden}.calendar-year-label-week{font-size:10px;padding-right:4px}.calendar-year-label-week.decade-label{font-size:11px}.calendar-months-outer{padding:10px 8px}.calendar-months-cols-1{grid-template-columns:30px repeat(12,minmax(4px,1fr))}.calendar-months-cols-2{grid-template-columns:30px repeat(12,minmax(4px,1fr)) 12px 30px repeat(12,minmax(4px,1fr))}.calendar-months-cols-5{grid-template-columns:30px repeat(12,minmax(4px,1fr)) 12px 30px repeat(12,minmax(4px,1fr)) 12px 30px repeat(12,minmax(4px,1fr)) 12px 30px repeat(12,minmax(4px,1fr)) 12px 30px repeat(12,minmax(4px,1fr))}.calendar-months-layout{column-gap:1px;row-gap:1px}.calendar-months-layout .calendar-cell{min-height:4px;min-width:4px}.calendar-month-label{font-size:8px;padding:1px}.calendar-year-label-month{font-size:10px;padding-right:4px}.calendar-year-label-month.decade-label{font-size:11px}.calendar-years-outer{padding:10px 8px}.calendar-years-layout{column-gap:1px;row-gap:1px}.calendar-years-cols-1{grid-template-columns:30px repeat(10,minmax(8px,1fr))}.calendar-years-cols-2{grid-template-columns:30px repeat(10,minmax(8px,1fr)) 12px 30px repeat(10,minmax(8px,1fr))}.calendar-years-layout .calendar-cell{min-height:8px;min-width:8px}.calendar-year-label-small{font-size:8px;padding:1px}.calendar-decade-label{font-size:11px;padding-right:4px}.decade-spacer{height:8px}.calendar-days-container{border-radius:8px;box-shadow:none;max-width:100%;padding:8px}.calendar-days-navigation{flex-direction:column;gap:10px}.nav-section{justify-content:center;width:100%}.nav-btn{padding:6px 12px}.nav-btn,.nav-select{font-size:.9rem}.calendar-days-with-arrows{gap:3px;margin-top:16px}.week-arrow-btn{flex-shrink:0;font-size:.8rem;height:26px;width:26px}.calendar-days-grid{flex:1 1;gap:3px;max-width:100%;min-width:0}.calendar-day-header{font-size:.75rem;padding:4px 2px}.calendar-day-cell{border-radius:4px;min-height:0}.day-number{font-size:1rem}}
/*# sourceMappingURL=main.8f74bcea.css.map*/