*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#e1e8ed;background:#0f0f0f}#root{min-height:100vh}button{font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#1a1a1a;border-radius:10px}::-webkit-scrollbar-thumb{background:#555;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#777}.app{min-height:100vh;background:#000;padding:12px}.app.loading{display:flex;align-items:center;justify-content:center}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top:3px solid #145987;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner p{color:#999;font-size:14px;margin:0}.main-content{max-width:1200px;margin:16px auto 0;display:grid;grid-template-columns:1fr 1fr;gap:20px}.calendar-section{display:flex;justify-content:center;align-items:flex-start;padding:20px}.goals-section{background:#000;border-radius:8px;border:1px solid #000000;padding:20px}@media (max-width: 768px){.main-content{grid-template-columns:1fr;gap:16px}.calendar-section{order:1;padding:16px}.goals-section{order:2;padding:16px}}.delete-modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.delete-modal-content{background:#1a1a1a;border-radius:12px;max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080}.delete-modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #333;background:#2a2a2a}.delete-modal-header h2{color:#ff5b5b;font-size:24px;font-weight:600;margin:0}.delete-modal-close{background:none;border:none;color:#888;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.delete-modal-close:hover{background:#333;color:#fff}.delete-modal-body{padding:32px;color:#e0e0e0;line-height:1.6;flex:1;overflow-y:auto}.warning-section{margin-bottom:32px}.warning-icon{font-size:48px;text-align:center;margin-bottom:16px}.warning-section h3{color:#ff5b5b;font-size:20px;font-weight:600;margin:0 0 16px;text-align:center}.warning-section p{margin:0 0 16px;color:#d0d0d0}.warning-section ul{margin:0 0 16px;padding-left:20px}.warning-section li{margin-bottom:8px;color:#d0d0d0}.warning-text{background:#ff44441a;color:#fff;padding:16px;border-radius:8px;text-align:center}.confirmation-section{margin-top:24px}.confirmation-section label{display:block;font-size:14px;font-weight:600;color:#e1e8ed;margin-bottom:8px}.confirm-input{width:100%;padding:12px 16px;background:#ffffff0d;border-radius:8px;color:#fff;font-size:16px;transition:all .3s ease;box-sizing:border-box}.confirm-input:focus{outline:none;background:#ffffff14}.confirm-input::placeholder{color:#666}.confirm-input:disabled{opacity:.6;cursor:not-allowed}.delete-modal-footer{padding:24px 32px;border-top:1px solid #333;background:#2a2a2a;display:flex;justify-content:flex-end;gap:12px}.cancel-btn{background:#444;color:#fff;border:none;padding:0;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;width:120px;height:44px;box-sizing:border-box;flex:none!important}.cancel-btn:hover:not(:disabled){background:#555}.cancel-btn:disabled{opacity:.6;cursor:not-allowed}.delete-btn{background:#f44;color:#fff;border:none;padding:0;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;width:120px;height:44px;box-sizing:border-box;flex:none!important}.delete-btn:hover:not(:disabled){background:#f66;transform:translateY(-1px)}.delete-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.delete-btn:active{transform:translateY(0)}@media (max-width: 768px){.delete-modal-overlay{padding:10px}.delete-modal-content{max-height:95vh}.delete-modal-header{padding:20px}.delete-modal-header h2{font-size:20px}.delete-modal-body{padding:24px 20px}.delete-modal-footer{padding:20px;flex-direction:row;gap:12px}.cancel-btn,.delete-btn{flex:1;height:48px;font-size:16px;font-weight:600}}@media (max-width: 480px){.delete-modal-body{padding:20px 16px}.delete-modal-header{padding:16px}.delete-modal-footer{padding:16px;gap:10px}.cancel-btn,.delete-btn{height:50px;font-size:16px;font-weight:600}.warning-icon{font-size:36px}}.header{text-align:center;margin-bottom:24px;display:flex;justify-content:center;padding:16px 0;background:linear-gradient(135deg,#ffffff05,#ffffff03);border-bottom:1px solid rgba(255,255,255,.05)}.header-content{max-width:600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;position:relative;padding:0 16px;min-height:60px;flex-wrap:nowrap}.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.header-icon{width:60px;height:60px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:30px;padding:0}.header-icon img{width:100%;height:100%;border-radius:10px;filter:brightness(0) saturate(100%) invert(100%);transition:all .3s ease}.header-icon:hover img{filter:brightness(0) saturate(100%) invert(100%) opacity(.8);transform:scale(1.05)}.header-title{font-size:2.2rem;color:#fff;margin:0;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:-.02em;display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;flex:1;min-width:0}.demo-badge{background:#ff6b6b;color:#fff;font-size:12px;font-weight:600;padding:2px 6px;border-radius:12px;letter-spacing:0}.header-subtitle{font-size:1rem;color:#8b9dc3;margin:0;font-weight:300}.install-btn{background:linear-gradient(135deg,#145987,#1a6ba3);color:#fff;border:none;padding:8px 12px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #1459874d;display:flex;align-items:center;gap:4px}.install-btn:hover{background:linear-gradient(135deg,#1a6ba3,#2079bf);transform:translateY(-1px);box-shadow:0 4px 12px #14598766}.install-btn:active{transform:translateY(0)}.user-menu{position:relative}.user-btn{display:flex;align-items:center;gap:8px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:25px;padding:6px 12px;margin-left:12px;color:#fff;cursor:pointer;transition:all .3s ease;font-size:14px;min-width:0;flex-shrink:0}.user-btn:hover{background:#ffffff1f;border-color:#ffffff40;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.user-avatar{width:32px;height:32px;background:linear-gradient(135deg,#145987,#1a6ba3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;color:#fff;overflow:hidden}.user-name{font-weight:500;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{font-size:10px;transition:transform .3s ease}.user-menu:hover .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{position:absolute;top:100%;right:0;margin-top:8px;background:#2d2d2d;border:1px solid rgba(255,255,255,.15);border-radius:12px;box-shadow:0 8px 24px #0006;min-width:220px;max-width:280px;z-index:1000;animation:dropdownSlideIn .2s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-info{padding:16px;border-bottom:1px solid rgba(255,255,255,.1)}.user-email{color:#fff;font-size:14px;font-weight:500;margin-bottom:4px}.login-time{color:#999;font-size:12px}.dropdown-actions{display:flex;flex-direction:column}.logout-btn{width:100%;background:transparent;border:none;color:#ff6b6b;padding:12px 16px;text-align:left;cursor:pointer;transition:background-color .3s ease;font-size:14px;border-bottom:1px solid rgba(255,255,255,.1)}.logout-btn:hover{background:#ff6b6b1a}.delete-account-btn{width:100%;background:transparent;border:none;color:#ff6b6b;padding:12px 16px;text-align:left;cursor:pointer;transition:background-color .3s ease;font-size:14px;border-radius:0 0 12px 12px;font-weight:500}.delete-account-btn:hover{background:#ff44441a}@media (max-width: 1024px){.header-content{max-width:500px;gap:10px}.header-title{font-size:2rem}}@media (max-width: 768px){.header{padding:10px 0;margin-bottom:16px}.header-content{max-width:100%;padding:0 12px;gap:8px}.header-icon{width:44px;height:44px}.header-title{font-size:1.6rem}.demo-badge{font-size:10px;padding:1px 4px}.install-btn{padding:6px 8px;font-size:10px}.user-btn{padding:4px 8px;gap:6px;font-size:13px;margin-left:10px}.user-name{max-width:70px;font-size:13px}.user-avatar{width:28px;height:28px;font-size:12px}.user-dropdown{min-width:200px;margin-top:6px}}@media (max-width: 480px){.header-content{gap:6px;padding:0 8px}.header-icon{width:36px;height:36px}.header-title{font-size:1.3rem;letter-spacing:-.5px}.demo-badge{font-size:9px;padding:1px 3px}.install-btn{padding:4px 6px;font-size:9px}.user-btn{padding:4px 6px;gap:4px;border-radius:20px;min-width:40px;margin-left:8px}.user-name{display:none}.user-avatar{width:28px;height:28px;font-size:11px}.dropdown-arrow{font-size:10px}.user-dropdown{min-width:180px;margin-top:4px;right:-10px}}@media (max-width: 360px){.header-title{font-size:1.1rem}.header-icon{width:32px;height:32px}.install-btn{display:none}.user-btn{padding:3px 5px;min-width:36px;margin-left:6px}.user-avatar{width:24px;height:24px;font-size:10px}.dropdown-arrow{font-size:8px}.user-dropdown{min-width:160px;margin-top:3px;right:-15px;font-size:13px}}.calendar{width:100%;max-width:350px;margin:0 auto;touch-action:pan-y;-webkit-user-select:none;user-select:none;cursor:grab}.calendar:active{cursor:grabbing}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 8px}.calendar-title{color:#fff;font-size:1rem;font-weight:600;margin:0}.nav-btn{background:transparent;border:none;color:#2d2d2d;padding:20px;cursor:pointer;font-size:40px;font-weight:700;transition:all .2s ease;border-radius:4px;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:16px}.day-header{color:#fff;padding:6px 3px;text-align:center;font-weight:500;font-size:10px;text-transform:uppercase}.day-header.sunday{color:#cd3861}.day-header.saturday{color:#6478ff}.calendar-day{background:#2d2d2d;width:32px;height:32px;border-radius:50%;cursor:pointer;transition:all .2s ease;position:relative;display:flex;align-items:center;justify-content:center;margin:0 auto}.calendar-day:hover{background:#3d3d3d}.calendar-day.other-month{background:transparent;opacity:.3}.calendar-day.other-month:hover{background:#2d2d2d;opacity:.5}.calendar-day.today{background:#fff}.calendar-day.today .day-number{color:#000;font-weight:700}.calendar-day.selected{background:#4a90e2}.calendar-day.selected .day-number{color:#fff;font-weight:600}.calendar-day.has-deadline{position:relative;background:#145987!important;border:2px solid #145987}.calendar-day.has-deadline .day-number{color:#fff!important;font-weight:600}.calendar-day.has-deadline.today{background:#145987!important;border:2px solid #ffdd00}.calendar-day.has-deadline.selected{background:#145987!important;border:2px solid #4a90e2}.calendar-day.has-deadline.today .day-number,.calendar-day.has-deadline.selected .day-number{color:#fff!important;font-weight:700}.day-number{color:#e1e8ed;font-weight:500;font-size:12px;margin:0}.calendar-day.other-month .day-number{color:#666}.calendar-day.sunday .day-number{color:#cd3861}.calendar-day.saturday .day-number{color:#6478ff}.calendar-day.sunday.today .day-number,.calendar-day.saturday.today .day-number{color:#000}.calendar-day.sunday.selected .day-number,.calendar-day.saturday.selected .day-number{color:#fff}@media (max-width: 768px){.calendar{max-width:280px}.calendar-day{width:28px;height:28px}.day-number{font-size:10px}.calendar-title{font-size:.9rem}.nav-btn{width:40px;height:40px;font-size:24px;padding:8px}}@media (max-width: 480px){.nav-btn{width:44px;height:44px;font-size:28px;padding:10px}}.calendar-stats{display:flex;justify-content:flex-start;gap:16px;margin-bottom:12px;margin-left:20px;padding:4px 8px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-label{color:#999;font-size:9px;font-weight:500}.stat-value{color:#fff;font-size:12px;font-weight:600}.stat-item.completed .stat-value{color:#145987}.stat-item.in-progress .stat-value{color:#e1e8ed}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#1a1a1a;border-radius:8px;border:1px solid #333;width:90%;max-width:450px;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .2s ease-out}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px 0;margin-bottom:16px}.modal-close{background:transparent;border:none;color:#8b9dc3;font-size:20px;cursor:pointer;padding:3px;border-radius:3px;transition:all .2s ease;width:26px;height:26px;display:flex;align-items:center;justify-content:center}.modal-form{padding:0 20px 20px}.modal-form .form-group{margin-bottom:16px}.modal-form .form-group label{display:block;margin-bottom:6px;font-weight:600;color:#e1e8ed;font-size:13px}.modal-form .form-group input,.modal-form .form-group select,.modal-form .form-group textarea{width:100%;padding:10px;border:1px solid #404040;border-radius:4px;font-size:16px;background:#333;color:#e1e8ed;transition:border-color .3s ease}.modal-form .form-group input:focus,.modal-form .form-group select:focus,.modal-form .form-group textarea:focus{outline:none;border-color:#666;background:#3a3a3a}.selected-date-display{padding:10px;color:#fff;font-weight:600;margin-bottom:16px;margin-left:10px;font-size:13px}.modal-actions{display:flex;gap:10px;margin-top:20px}.cancel-btn{flex:1;background:transparent;color:#8b9dc3;border:1px solid #555;padding:10px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-form .submit-btn{flex:1;background:transparent;color:#fff;border:1px solid #ffffff;padding:10px;border-radius:4px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.date-helper{margin-top:4px}.date-helper small{color:#8b9dc3;font-size:11px}.error-message{margin-top:3px;color:#ff6b6b;font-size:11px;font-weight:500}.category-input-group{display:flex;flex-direction:column;gap:10px}.category-input-group input[type=text]{flex:1}.color-picker-container{display:flex;align-items:center;gap:6px}.color-picker-label{font-size:11px;color:#8b9dc3;margin:0;min-width:25px}.color-picker{width:35px;height:25px;border:1px solid #555;border-radius:3px;background:none;cursor:pointer;padding:0}.color-picker:focus{outline:none;border-color:#777}.color-preview{width:25px;height:25px;border:1px solid #555;border-radius:3px;cursor:pointer}@media (max-width: 768px){.modal-content{width:95%;margin:20px}.modal-header{padding:20px 20px 0}.modal-form{padding:0 20px 20px}}.goal-list{background:transparent;padding:0}.goal-list h2{color:#fff;margin-bottom:25px;font-size:1.5rem;border-bottom:2px solid #444;padding-bottom:10px}.goals-container{display:flex;flex-direction:column;gap:16px}.category-group{margin-bottom:20px}.category-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px 12px;border-radius:6px}.category-indicator{width:6px;height:6px;border-radius:50%;flex-shrink:0}.category-title{color:#fff;font-size:.85rem;font-weight:500;margin:0;flex:1}.category-goals{display:flex;flex-direction:column;gap:0}.category-goals .goal-item:not(:last-child){border-bottom:1px solid #333}@media (max-width: 768px){.goal-list{padding:20px}}.goal-item{background:#000;border-radius:6px;padding:12px;margin-bottom:12px;border-bottom:1px solid #444}.goal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:0}.goal-title-section{display:flex;align-items:center;gap:10px;flex:1}.goal-content{display:flex;align-items:center;gap:8px;flex:1}.expand-btn{background:transparent;border:none;color:#999;font-size:12px;cursor:pointer;padding:4px 6px;border-radius:3px;transition:all .2s ease}.goal-details{margin-top:8px;padding:8px;background:#1a1a1a;border-radius:4px}.dates-info{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}.goal-title{margin:0;color:#fff;font-size:.9rem;font-weight:400;flex:1}.goal-category{padding:4px 8px;border-radius:4px;font-size:10px;font-weight:500;color:#fff;white-space:nowrap;margin-right:10px}.goal-actions{display:flex;align-items:center;gap:6px;flex-shrink:0;opacity:1;transition:opacity .2s ease}.dday{padding:4px 8px;background:#2d2d2d;color:#fff;border-radius:4px;font-weight:500;font-size:11px;border:1px solid #444}.dday.overdue{background:#dc3545}.edit-btn,.delete-btn{padding:6px 12px;border:1px solid #555;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;background:transparent}.edit-btn{color:#8b9dc3;border-color:#555}.edit-btn:hover{background:#333;color:#fff}.delete-btn{color:#ff6b6b;border-color:#ff6b6b}.delete-btn:hover{background:#ff6b6b;color:#fff}.goal-dates{display:flex;gap:10px;margin-bottom:10px;font-size:12px;color:#8b9dc3}.date{color:#fff;font-size:11px}.progress-section{margin:6px 0}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;font-size:10px;color:#666}.progress-controls{display:flex;align-items:center;gap:5px}.progress-input{width:45px;padding:2px 4px;border:1px solid #555;border-radius:3px;font-size:16px;font-weight:600;text-align:center;color:#fff;background:#333}.progress-input:focus{outline:none;border-color:#777;background:#3a3a3a}.progress-percent{font-weight:600;color:#8b9dc3;font-size:11px}.progress-bar-container{margin-bottom:8px}.progress-bar{width:100%;height:4px;background:#2d2d2d;border-radius:2px;overflow:hidden;transition:all .2s ease;position:relative}.progress-bar.interactive{cursor:pointer;-webkit-user-select:none;user-select:none}.progress-bar.interactive:hover{height:10px;background:#4a4a4a;transform:translateY(-1px)}.progress-bar.dragging{height:12px;background:#4a4a4a;box-shadow:0 2px 8px #ffffff1a;transform:translateY(-2px)}.progress-fill{height:100%;background:#145987;border-radius:2px;position:relative;transition:width .3s ease}.progress-thumb{position:absolute;top:50%;width:16px;height:16px;background:#fff;border:2px solid #666;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 2px 6px #0000004d;cursor:grab;z-index:5}.progress-thumb:active{cursor:grabbing;transform:translate(-50%,-50%) scale(1.1)}.progress-tooltip{position:absolute;top:-35px;background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;transform:translate(-50%);white-space:nowrap;z-index:10;animation:tooltipFadeIn .15s ease-out}.progress-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:4px solid transparent;border-top-color:#333}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-5px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.progress-actions{display:flex;align-items:center;gap:8px;background:#333;padding:10px;border-radius:6px;border:1px solid #555}.progress-btn{padding:4px 8px;border:1px solid #555;border-radius:4px;background:transparent;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:45px;color:#e1e8ed}.progress-btn:hover:not(:disabled){background:#444}.progress-btn:disabled{opacity:.3;cursor:not-allowed}.progress-btn.decrease,.progress-btn.decrease-small{color:#ff6b6b;border-color:#ff6b6b}.progress-btn.decrease:hover:not(:disabled),.progress-btn.decrease-small:hover:not(:disabled){background:#ff6b6b;color:#fff}.progress-btn.increase,.progress-btn.increase-small{color:#4ecdc4;border-color:#4ecdc4}.progress-btn.increase:hover:not(:disabled),.progress-btn.increase-small:hover:not(:disabled){background:#4ecdc4;color:#000}.progress-slider{flex:1;margin:0 10px;height:6px;background:#555;border-radius:3px;outline:none;-webkit-appearance:none;appearance:none}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:#fff;cursor:pointer;box-shadow:0 2px 4px #0000004d;transition:transform .2s ease}.progress-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.progress-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#fff;cursor:pointer;border:none;box-shadow:0 2px 4px #0000004d}.goal-memo{background:#2d2d2d;padding:6px 8px;border-radius:3px;font-size:10px;color:#fff;margin-top:6px}.completion-badge{background:#2d2d2d;color:#fff;padding:6px;border-radius:4px;text-align:center;font-weight:600;margin-top:8px;font-size:12px}.edit-title-section{display:flex;flex-direction:column;gap:8px;width:100%}.edit-title-input{background:#333;border:1px solid #555;border-radius:4px;padding:8px 12px;color:#fff;font-size:16px;font-weight:600;margin-right:10px}.edit-title-input:focus{outline:none;border-color:#777;background:#3a3a3a}.edit-category-group{display:flex;align-items:center;gap:8px}.edit-category-input{background:#333;border:1px solid #555;border-radius:4px;padding:6px 10px;color:#e1e8ed;font-size:16px;flex:1;min-width:120px}.edit-category-input:focus{outline:none;border-color:#777;background:#3a3a3a}.edit-color-picker{width:30px;height:24px;border:1px solid #555;border-radius:4px;background:none;cursor:pointer;padding:0;margin-right:10px}.edit-color-picker:focus{outline:none;border-color:#777}.edit-dates-section{display:flex;flex-direction:column;gap:10px;margin-bottom:15px}.edit-date-group{display:flex;align-items:center;gap:8px}.edit-date-group label{font-size:14px;color:#8b9dc3;min-width:50px}.edit-date-input{background:#333;border:1px solid #555;border-radius:4px;padding:6px 10px;color:#e1e8ed;font-size:16px;width:120px}.edit-date-input:focus{outline:none;border-color:#777;background:#3a3a3a}.edit-error-message{color:#ff6b6b;font-size:12px;font-weight:500;margin-top:4px}.edit-memo-section{margin-bottom:15px}.edit-memo-section label{display:block;font-size:14px;color:#8b9dc3;margin-bottom:8px}.edit-memo-textarea{width:100%;background:#333;border:1px solid #555;border-radius:4px;padding:10px;color:#e1e8ed;font-size:16px;resize:vertical;min-height:60px}.edit-memo-textarea:focus{outline:none;border-color:#777;background:#3a3a3a}.save-btn,.cancel-btn{padding:8px 16px;border:1px solid #555;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;background:transparent;width:70px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.save-btn:first-child{margin-left:0}.save-btn{color:#fff;border-color:#fff}.save-btn:hover{background:#777;color:#000}.cancel-btn{color:#ff6b6b;border-color:#ff6b6b}.dropdown-container{position:relative;display:inline-block}.more-btn{background:transparent;border:none;border-radius:3px;color:#999;padding:4px 6px;font-size:14px;font-weight:400;cursor:pointer;transition:all .2s ease;line-height:1}.dropdown-menu{position:absolute;top:100%;right:0;background:#2d2d2d;border:1px solid #555;border-radius:6px;box-shadow:0 4px 12px #0000004d;z-index:10;min-width:80px;overflow:hidden;animation:dropdownSlideIn .15s ease-out}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{width:100%;background:transparent;border:none;color:#e1e8ed;padding:8px 6px;font-size:13px;text-align:center;cursor:pointer;transition:background-color .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.dropdown-item:hover{background:#3a3a3a}.dropdown-item.delete{color:#ff6b6b}.dropdown-item.delete:hover{background:#ff6b6b;color:#fff}@media (max-width: 768px){.goal-header{flex-direction:column;gap:10px;align-items:flex-start}.goal-actions{align-self:stretch;justify-content:space-between}.progress-actions{flex-wrap:wrap;gap:5px}.progress-btn{font-size:10px;padding:3px 6px;min-width:40px}.progress-slider{margin:5px 0;order:10;flex-basis:100%}.edit-title-section{gap:10px}.edit-dates-section{gap:12px}.edit-date-group{flex-direction:column;align-items:flex-start;gap:4px}.edit-date-input{width:100%}.edit-memo-textarea{min-height:80px}.dropdown-menu{right:-10px;min-width:100px}.dropdown-item{padding:12px 10px;font-size:13px}}.privacy-overlay{position:fixed;inset:0;background-color:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.privacy-modal{background:#1a1a1a;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080}.privacy-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;border-bottom:1px solid #333;background:#2a2a2a}.privacy-header h2{color:#fff;font-size:24px;font-weight:600;margin:0}.privacy-close{background:none;border:none;color:#888;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s ease}.privacy-close:hover{background:#333;color:#fff}.privacy-content{flex:1;overflow-y:auto;padding:32px;color:#e0e0e0;line-height:1.6}.privacy-section h3{color:#fff;font-size:18px;font-weight:600;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #444}.privacy-footer{padding:24px 32px;border-top:1px solid #333;background:#2a2a2a;display:flex;justify-content:center}.privacy-agree-btn{background:#4a9eff;color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.privacy-agree-btn:hover{background:#3a8eef;transform:translateY(-1px)}.privacy-agree-btn:active{transform:translateY(0)}.privacy-content::-webkit-scrollbar{width:8px}.privacy-content::-webkit-scrollbar-track{background:#2a2a2a;border-radius:4px}.privacy-content::-webkit-scrollbar-thumb{background:#555;border-radius:4px}.privacy-content::-webkit-scrollbar-thumb:hover{background:#666}@media (max-width: 768px){.privacy-overlay{padding:10px}.privacy-modal{max-height:95vh}.privacy-header{padding:20px}.privacy-header h2{font-size:20px}.privacy-content{padding:24px 20px}.privacy-footer{padding:20px}.privacy-section h3{font-size:16px}.privacy-section h4{font-size:14px}}@media (max-width: 480px){.privacy-content{padding:20px 16px}.privacy-header,.privacy-footer{padding:16px}}.login-container{min-height:100vh;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);display:flex;align-items:center;justify-content:center;padding:20px}.forgot-password-link{margin-top:8px;text-align:right}.forgot-password-btn{background:none;border:none;color:#8b9dc3;font-size:12px;cursor:pointer;text-decoration:underline;transition:color .2s ease}.forgot-password-btn:hover{color:#fff}.forgot-password-btn:disabled{opacity:.5;cursor:not-allowed}.login-card{border-radius:20px;padding:40px;width:100%;max-width:400px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:32px}.login-icon{width:80px;height:80px;margin:0 auto 16px;background:#ffffff1a;border-radius:20px;display:flex;align-items:center;justify-content:center;border:2px solid rgba(255,255,255,.2)}.login-icon img{width:60px;height:60px;border-radius:12px;filter:brightness(0) saturate(100%) invert(100%)}.login-title{font-size:2.5rem;font-weight:800;color:#fff;margin:0 0 8px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.login-subtitle{font-size:1rem;color:#999;margin:0;font-weight:400}.login-form{margin-bottom:24px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:14px;font-weight:600;color:#e1e8ed;margin-bottom:8px}.form-input{width:100%;padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#145987;background:#ffffff14;box-shadow:0 0 0 3px #14598733}.error-message{background:#ff6b6b1a;border:1px solid rgba(255,107,107,.3);color:#ff6b6b;padding:12px 16px;border-radius:12px;margin-bottom:20px;font-size:14px;text-align:center}.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,#145987,#1a6ba3);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:24px}.login-btn:active{transform:translateY(0)}.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-switch{text-align:center;margin-bottom:20px}.switch-text{color:#999;font-size:14px;margin:0 0 8px}.switch-btn{background:transparent;color:#145987;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:color .3s ease;text-decoration:underline}.switch-btn:hover:not(:disabled){color:#1a6ba3}.switch-btn:disabled{opacity:.6;cursor:not-allowed}.demo-section{text-align:center;padding:20px 0;border-top:1px solid rgba(255,255,255,.1)}.demo-text{color:#999;font-size:14px;margin:0 0 12px}.demo-btn{background:transparent;color:#145987;border:1px solid #145987;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.demo-btn:hover:not(:disabled){background:#1459871a;color:#1a6ba3}.demo-btn:disabled{opacity:.6;cursor:not-allowed}.login-footer{text-align:center;padding-top:20px;border-top:1px solid rgba(255,255,255,.05)}.footer-text{color:#666;font-size:12px;margin:0}@media (max-width: 768px){.login-container{padding:16px}.login-card{padding:32px 24px}.login-icon{width:70px;height:70px}.login-icon img{width:50px;height:50px;filter:brightness(0) saturate(100%) invert(100%)}.login-title{font-size:2rem}.login-subtitle{font-size:.9rem}}@media (max-width: 480px){.login-card{padding:28px 20px}.login-title{font-size:1.8rem}.social-btn{font-size:14px;padding:10px 14px}.social-icon{width:18px;height:18px}.divider{margin:20px 0 16px}}.divider{display:flex;align-items:center;margin:24px 0 20px;color:#666;font-size:14px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.divider span{padding:0 16px;background:#1a1a1a;color:#999;font-weight:500}.social-login{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.social-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:12px 16px;border:1px solid rgba(255,255,255,.2);border-radius:12px;background:#ffffff0d;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none}.social-btn:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.social-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.social-icon{width:20px;height:20px;flex-shrink:0}.google-btn:hover:not(:disabled){border-color:#4285f4;box-shadow:0 4px 12px #4285f433}.github-btn:hover:not(:disabled){border-color:#333;box-shadow:0 4px 12px #0000004d}.privacy-notice{margin:16px 0;padding:16px;background:#1459871a;border:1px solid rgba(20,89,135,.2);border-radius:12px;text-align:center}.privacy-text{color:#d0d0d0;font-size:13px;margin:0;line-height:1.5}.privacy-link{background:none;border:none;color:#4a9eff;font-size:13px;font-weight:600;cursor:pointer;text-decoration:underline;padding:0;transition:color .2s ease}.privacy-link:hover:not(:disabled){color:#6bb6ff}.privacy-link:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#1a1a1a;border-radius:12px;border:1px solid #333;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;position:relative;animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0;margin-bottom:16px}.modal-header h2{color:#fff;margin:0;font-size:1.2rem;font-weight:600}.modal-close{background:transparent;border:none;color:#8b9dc3;font-size:24px;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:#333;color:#fff}.modal-form{padding:0 24px 24px}.modal-actions{display:flex;gap:12px;margin-top:20px;align-items:stretch}.modal-actions .cancel-btn{flex:none;width:160px;height:44px;background:transparent;color:#ff6b6b;border:1px solid #555;padding:0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-sizing:border-box;white-space:nowrap;margin:0;position:relative;top:0}.modal-actions .cancel-btn:hover{background:#333;color:#fff}.modal-actions .submit-btn{flex:none;width:160px;height:44px;background:transparent;color:#8b9dc3;border:1px solid #555;padding:0;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;box-sizing:border-box;white-space:nowrap;margin:0;position:relative;top:0}.modal-actions .submit-btn:hover{background:#333;color:#fff}.message{margin-top:12px;padding:12px;border-radius:8px;font-size:14px;font-weight:500}.message.success{background:#4caf501a;color:#4caf50;border:1px solid rgba(76,175,80,.2)}.message.error{background:#f443361a;color:#f44336;border:1px solid rgba(244,67,54,.2)}@media (max-width: 768px){.modal-actions{flex-direction:column;gap:12px}.modal-actions .cancel-btn,.modal-actions .submit-btn{width:100%;min-width:auto;height:48px;font-size:16px}}@media (max-width: 480px){.modal-actions .cancel-btn,.modal-actions .submit-btn{height:50px;font-size:16px}}.reset-password-container{min-height:100vh;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);display:flex;align-items:center;justify-content:center;padding:20px}.reset-password-card{background:#1a1a1ae6;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:40px;width:100%;max-width:400px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 20px 40px #0000004d}.reset-password-header{text-align:center;margin-bottom:32px}.reset-password-header h2{font-size:2rem;font-weight:700;color:#fff;margin:0 0 8px}.reset-password-header p{color:#8b9dc3;font-size:14px;margin:0}.reset-password-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{color:#e1e8ed;font-size:14px;font-weight:600}.form-input{padding:12px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:16px;transition:all .3s ease;box-sizing:border-box}.form-input:focus{outline:none;border-color:#4a9eff;background:#ffffff14;box-shadow:0 0 0 3px #4a9eff1a}.form-input::placeholder{color:#666}.form-input:disabled{opacity:.6;cursor:not-allowed}.submit-btn{background:#3a8eef;color:#000;border:none;border-radius:12px;padding:14px 24px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:8px}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#3a8eef,#2a7edf);transform:translateY(-2px);box-shadow:0 8px 20px #4a9eff4d}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.error-message{background:#f443361a;color:#f44336;border:1px solid rgba(244,67,54,.2);border-radius:8px;padding:12px;font-size:14px;font-weight:500;text-align:center}.success-icon{width:80px;height:80px;background:#4caf501a;border:2px solid #4caf50;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#4caf50;margin:0 auto 24px}.reset-password-card h2{color:#fff;text-align:center;margin-bottom:16px}.reset-password-card p{color:#8b9dc3;text-align:center;margin:0}@media (max-width: 480px){.reset-password-container{padding:16px}.reset-password-card{padding:24px}.reset-password-header h2{font-size:1.5rem}}.privacy-page{min-height:100vh;background:linear-gradient(135deg,#0f0f0f,#1a1a1a);padding:20px}.privacy-page-container{max-width:800px;margin:0 auto;background:#1a1a1a;border-radius:12px;overflow:hidden;box-shadow:0 20px 40px #00000080}.privacy-page-header{background:#2a2a2a;padding:24px 32px;border-bottom:1px solid #333;display:flex;align-items:center;gap:20px}.back-btn{background:#444;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:8px}.back-btn:hover{background:#555;transform:translateY(-1px)}.back-btn:active{transform:translateY(0)}.privacy-page-header h1{color:#fff;font-size:28px;font-weight:700;margin:0}.privacy-page-content{padding:32px;color:#e0e0e0;line-height:1.6}.privacy-section{margin-bottom:32px}.privacy-section:last-child{margin-bottom:0}.privacy-section h3{color:#fff;font-size:20px;font-weight:600;margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid #444}.privacy-section h4{color:#fff;font-size:16px;font-weight:500;margin:20px 0 12px}.privacy-section p{margin:0 0 16px;color:#d0d0d0}.privacy-section ul{margin:0 0 16px;padding-left:20px}.privacy-section li{margin-bottom:8px;color:#d0d0d0}.privacy-section strong{color:#fff;font-weight:600}.contact-info{background:#2a2a2a;padding:20px;border-radius:8px;border-left:4px solid #4a9eff;margin:16px 0}.contact-info p{margin:0 0 8px}.contact-info p:last-child{margin-bottom:0}@media (max-width: 768px){.privacy-page{padding:10px}.privacy-page-header{padding:20px;flex-direction:column;align-items:flex-start;gap:16px}.privacy-page-header h1{font-size:24px}.privacy-page-content{padding:24px 20px}.privacy-section h3{font-size:18px}.privacy-section h4{font-size:14px}}@media (max-width: 480px){.privacy-page-content{padding:20px 16px}.privacy-page-header{padding:16px}.privacy-page-header h1{font-size:20px}.back-btn{padding:8px 12px;font-size:13px}}
