*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.fixed{position:fixed}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.ml-2{margin-left:.5rem}.ml-4{margin-left:1rem}.mr-2{margin-right:.5rem}.mr-4{margin-right:1rem}.mt-1{margin-top:.25rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.inline-block{display:inline-block}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.h-12{height:3rem}.min-h-0{min-height:0px}.min-h-\[80px\]{min-height:80px}.min-h-screen{min-height:100vh}.w-12{width:3rem}.flex-1{flex:1 1 0%}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.5rem * var(--tw-space-x-reverse));margin-left:calc(.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse: 0;margin-right:calc(.75rem * var(--tw-space-x-reverse));margin-left:calc(.75rem * calc(1 - var(--tw-space-x-reverse)))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-gray-200>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(229 231 235 / var(--tw-divide-opacity, 1))}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-t{border-top-width:1px}.border-t-0{border-top-width:0px}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-gray-200{--tw-border-opacity: 1;border-color:rgb(229 231 235 / var(--tw-border-opacity, 1))}.border-transparent{border-color:transparent}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity, 1))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-transparent{background-color:transparent}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.p-0{padding:0}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--primary-color: #111827;--light-gray: #f7f7f7;--medium-gray: #e5e7eb;--dark-gray: #6b7280;--text-color: #111827;--bg-color: #f9fafb;--card-bg: white;--card-shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--border-radius: 8px;--header-bg: white;--form-bg: #f9fafb}[data-theme=dark]{--primary-color: #6366f1;--light-gray: #1f2937;--medium-gray: #374151;--dark-gray: #9ca3af;--text-color: #f3f4f6;--bg-color: #111827;--card-bg: #1f2937;--card-shadow: 0 1px 3px 0 rgba(0, 0, 0, .3), 0 1px 2px 0 rgba(0, 0, 0, .2);--header-bg: #1f2937;--form-bg: #111827}html,body,#root{margin:0;padding:0;min-height:100vh}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;background-color:var(--bg-color);color:var(--text-color);line-height:1.5;transition:background-color .3s ease,color .3s ease}#root{background-color:var(--bg-color);transition:background-color .3s ease}.site-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;border-bottom:1px solid var(--medium-gray);background-color:var(--header-bg);transition:background-color .3s ease}.site-title{font-size:1.5rem;font-weight:700;color:var(--text-color);text-decoration:none}.auth-links{margin-left:auto}.card{background-color:var(--card-bg);border-radius:var(--border-radius);box-shadow:var(--card-shadow);overflow:hidden;margin-bottom:1.5rem;transition:background-color .3s ease,box-shadow .3s ease}.card-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--medium-gray)}.card-body{padding:1.5rem}.chart-container{position:relative;height:400px;width:100%}.progress-card h2{font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.progress-subtitle{color:var(--dark-gray);margin-bottom:2rem}.progress-outer{width:100%;background-color:var(--light-gray);border-radius:9999px;height:.75rem}.progress-inner{background-color:var(--primary-color);height:100%;border-radius:9999px;transition:width .3s ease}.entries-table{width:100%;border-collapse:collapse}.entries-table th{padding:.75rem 1rem;text-align:left;font-weight:500;color:var(--dark-gray);border-bottom:1px solid var(--medium-gray)}.entries-table td{padding:1rem;border-bottom:1px solid var(--medium-gray)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background-color:var(--primary-color);color:#fff;border:none}.btn-primary:hover{background-color:#4338ca}.btn-secondary{background-color:#fff;color:var(--text-color);border:1px solid var(--medium-gray)}.btn-secondary:hover{background-color:var(--light-gray)}.btn-icon{margin-right:.5rem}.form-group{margin-bottom:1rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500}.form-input{width:100%;padding:.5rem .75rem;border:1px solid var(--medium-gray);border-radius:.375rem;transition:border-color .2s;background-color:var(--card-bg);color:var(--text-color)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #4f46e533}.switch{position:relative;display:inline-block;width:48px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:var(--primary-color)}input:focus+.slider{box-shadow:0 0 1px var(--primary-color)}input:checked+.slider:before{transform:translate(24px)}.slider.round{border-radius:24px}.slider.round:before{border-radius:50%}.notes-preview{position:relative;display:inline-block;max-width:100%}.notes-preview:after{content:"";position:absolute;top:0;right:0;width:30%;height:100%;background:linear-gradient(to right,rgba(255,255,255,0),var(--card-bg));pointer-events:none}[data-theme=dark] .notes-preview:after{background:linear-gradient(to right,rgba(31,41,55,0),var(--card-bg))}.editable-cell{cursor:pointer;position:relative;transition:background-color .2s}.editable-cell:hover{background-color:#5a5a5f0d}.editable-cell:hover:after{content:"✏️";font-size:.8em;position:absolute;right:5px;top:50%;transform:translateY(-50%);opacity:.3}.inline-edit-input{width:100%;padding:.25rem .5rem;border:1px solid var(--primary-color);border-radius:.25rem;font-size:inherit;font-family:inherit;background-color:var(--card-bg);color:var(--text-color);outline:none;box-shadow:0 0 0 2px #5c5c5f33}.settings-dropdown{position:absolute;top:100%;right:0;z-index:1000;min-width:150px;background-color:var(--card-bg);border:1px solid var(--medium-gray);border-radius:var(--border-radius);box-shadow:var(--card-shadow);margin-top:.25rem;overflow:hidden;transition:opacity .2s ease,transform .2s ease}.settings-dropdown.hidden{opacity:0;transform:translateY(-10px);pointer-events:none}.settings-dropdown:not(.hidden){opacity:1;transform:translateY(0)}.dropdown-item{width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;color:var(--text-color);cursor:pointer;transition:background-color .2s;display:flex;align-items:center;font-size:.875rem}.dropdown-item:hover{background-color:var(--light-gray)}.dropdown-item:not(:last-child){border-bottom:1px solid var(--medium-gray)}.dropdown-item .btn-icon{margin-right:.5rem}.project-selector{position:relative}.project-button{display:flex;align-items:center;padding:.5rem 1rem;background-color:var(--light-gray);border:1px solid var(--medium-gray);border-radius:var(--border-radius);color:var(--text-color);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.project-button:hover{background-color:var(--medium-gray)}.project-arrow{margin-left:.5rem;font-size:.75rem;transition:transform .2s ease}.project-dropdown{position:absolute;top:100%;left:0;z-index:1000;min-width:200px;background-color:var(--card-bg);border:1px solid var(--medium-gray);border-radius:var(--border-radius);box-shadow:var(--card-shadow);margin-top:.25rem;overflow:hidden;transition:opacity .2s ease,transform .2s ease}.project-dropdown.hidden{opacity:0;transform:translateY(-10px);pointer-events:none}.project-dropdown:not(.hidden){opacity:1;transform:translateY(0)}.project-item,.create-project-item{width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;color:var(--text-color);cursor:pointer;transition:background-color .2s;display:flex;align-items:center;font-size:.875rem}.project-item:hover,.create-project-item:hover{background-color:var(--light-gray)}.project-item.active{background-color:var(--primary-color);color:#fff}.project-item.active:hover{background-color:var(--primary-color);opacity:.9}.create-project-item{border-top:1px solid var(--medium-gray);font-weight:500}.create-project-item .btn-icon{margin-right:.5rem}.project-name{flex:1;text-align:left}.project-actions{display:flex;align-items:center;gap:.25rem;margin-left:auto;opacity:0;transition:opacity .2s}.project-item:hover .project-actions{opacity:1}.project-rename,.project-delete{font-size:.75rem;padding:.25rem;border-radius:.25rem;cursor:pointer;transition:background-color .2s}.project-rename:hover{background-color:#3b82f61a;color:#3b82f6}.project-delete:hover{background-color:#ef44441a;color:#ef4444}.tab-button{border-bottom:2px solid transparent;transition:all .2s ease}.tab-button.active{border-bottom-color:var(--primary-color);color:var(--primary-color)}.tab-button:hover{border-bottom-color:var(--dark-gray)}.tab-content{display:block}.tab-content.hidden{display:none}.task-item{padding:1rem;display:flex;align-items:center;gap:1rem;transition:background-color .2s}.task-item:hover{background-color:var(--light-gray)}.task-checkbox{width:1.25rem;height:1.25rem;border:2px solid var(--medium-gray);border-radius:.25rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.task-checkbox:hover{border-color:var(--primary-color)}.task-checkbox.completed{background-color:var(--primary-color);border-color:var(--primary-color)}.task-checkbox.completed:after{content:"✓";color:#fff;font-weight:700;font-size:.875rem}.task-content{flex:1}.task-description{font-weight:500;transition:all .2s}.task-description.completed{text-decoration:line-through;color:var(--dark-gray)}.task-date{font-size:.875rem;color:var(--dark-gray);margin-top:.25rem}.task-actions{display:flex;gap:.5rem;opacity:0;transition:opacity .2s}.task-item:hover .task-actions{opacity:1}.task-delete-btn{padding:.5rem;border:none;background:none;cursor:pointer;border-radius:.25rem;transition:background-color .2s;color:var(--dark-gray)}.task-delete-btn:hover{background-color:#ef44441a;color:#ef4444}.EasyMDEContainer{display:flex!important;flex-direction:column!important;flex-grow:1!important;overflow:hidden!important;height:100%!important}.CodeMirror{flex-grow:1!important;height:auto!important;min-height:300px!important}.CodeMirror-scroll{min-height:300px!important}.hover\:border-gray-300:hover{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity, 1))}.hover\:bg-blue-100:hover{--tw-bg-opacity: 1;background-color:rgb(219 234 254 / var(--tw-bg-opacity, 1))}.hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-300:hover{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-400:hover{--tw-bg-opacity: 1;background-color:rgb(156 163 175 / var(--tw-bg-opacity, 1))}.hover\:bg-green-600:hover{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.hover\:text-gray-400:hover{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.hover\:text-red-600:hover{--tw-text-opacity: 1;color:rgb(220 38 38 / var(--tw-text-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}@media (min-width: 768px){.md\:col-span-2{grid-column:span 2 / span 2}.md\:col-span-3{grid-column:span 3 / span 3}.md\:col-span-4{grid-column:span 4 / span 4}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.md\:p-8{padding:2rem}}@media (prefers-color-scheme: dark){.dark\:text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.dark\:text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.dark\:hover\:bg-blue-900:hover{--tw-bg-opacity: 1;background-color:rgb(30 58 138 / var(--tw-bg-opacity, 1))}}
