:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark light;--bg-body: #09090b;--bg-card: #18181b;--text-main: #e4e4e7;--text-muted: #a1a1aa;--border-color: #27272a;--level-0: #27272a;--level-1: #0e4429;--level-2: #006d32;--level-3: #26a641;--level-4: #39d353;--holiday-color: #fbbf24;--weekend-color: #22d3ee;--today-border: rgba(244, 63, 94, .5);--today-glow: rgba(244, 63, 94, .25);--hover-border: rgba(255, 255, 255, .5);--cell-size: 22px;--cell-gap: 5px;--border-radius: 4px}@media(prefers-color-scheme:light){:root{--bg-body: #f4f4f5;--bg-card: #ffffff;--text-main: #18181b;--text-muted: #71717a;--border-color: #e4e4e7;--level-0: #ebedf0;--level-1: #9be9a8;--level-2: #40c463;--level-3: #30a14e;--level-4: #216e39;--holiday-color: #d97706;--weekend-color: #0891b2;--today-border: #ef4444;--today-glow: rgba(239, 68, 68, .4)}}body{margin:0;min-width:320px;min-height:100vh;background-color:var(--bg-body);color:var(--text-main);overflow-x:hidden}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.app-shell{width:100%;position:relative}.page-view{display:none;width:100%;box-sizing:border-box;padding-top:56px}.page-view.active{display:block}.menu-toggle{position:fixed;top:20px;left:20px;width:48px;height:48px;border:1px solid var(--border-color);border-radius:14px;background:color-mix(in srgb,var(--bg-card) 88%,transparent);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);display:flex;flex-direction:column;justify-content:center;gap:5px;padding:0 12px;cursor:pointer;z-index:310}.menu-toggle span{display:block;width:100%;height:2px;border-radius:999px;background:var(--text-main)}.app-drawer-overlay{position:fixed;inset:0;background:#09090b73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:320}.app-drawer{position:fixed;top:0;left:0;width:min(280px,82vw);height:100vh;background:var(--bg-card);border-right:1px solid var(--border-color);box-shadow:12px 0 32px #0000002e;transform:translate(-100%);transition:transform .28s ease;z-index:330;padding:24px 18px;box-sizing:border-box}.app-drawer.open{transform:translate(0)}.drawer-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;text-align:left}.drawer-title{font-size:1.1rem;font-weight:700}.drawer-subtitle{margin-top:6px;color:var(--text-muted);font-size:.9rem}.drawer-close{border:none;background:transparent;color:var(--text-muted);font-size:1.8rem;cursor:pointer;line-height:1}.drawer-nav{display:flex;flex-direction:column;gap:10px}.drawer-link{border:1px solid var(--border-color);background:transparent;color:var(--text-main);padding:14px 16px;border-radius:14px;text-align:left;font-size:1rem;cursor:pointer;transition:all .2s ease}.drawer-link.active{background:linear-gradient(135deg,var(--weekend-color),#14b8a6);color:#fff;border-color:transparent}header{margin-bottom:2rem}h1{margin-top:0;font-size:2.5em;line-height:1.1;margin-bottom:.5rem;background:linear-gradient(to right,var(--text-main),var(--text-muted));-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:600;letter-spacing:-.05em}.year-title{cursor:pointer;display:inline-block}.year-title:hover{text-decoration:underline;text-underline-offset:4px}.subtitle{color:var(--text-muted);font-size:.9em}.offline-badge{display:inline-block;margin-top:8px;padding:4px 12px;background-color:#f59e0b;color:#fff;font-size:.75rem;font-weight:600;border-radius:9999px;opacity:1;transition:opacity .3s ease}.offline-badge.hidden{display:none}.heatmap-container{display:flex;flex-direction:column;gap:var(--cell-gap);padding:24px 6px;background:var(--bg-card);border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-color);overflow-x:auto;max-width:100%;box-sizing:border-box}.decade-row{display:flex;gap:var(--cell-gap);align-items:center}.row-label{width:20px;text-align:right;font-size:10px;color:var(--text-muted);margin-right:8px;font-family:monospace}.day-cell{width:var(--cell-size);height:var(--cell-size);background-color:var(--level-0);border-radius:var(--border-radius);transition:transform .1s ease,outline .1s ease;position:relative;cursor:pointer}.day-cell:hover{transform:scale(1.3);z-index:10;outline:1px solid var(--text-main)}#tooltip{position:fixed;background:var(--bg-body);color:var(--text-main);border:1px solid var(--border-color);padding:4px 8px;border-radius:4px;font-size:10px;white-space:nowrap;pointer-events:none;z-index:9999;opacity:0;transition:opacity .15s ease;box-shadow:0 4px 12px #00000026;transform:translate(-50%,-100%);margin-top:-8px}.day-cell[data-level="1"]{background-color:var(--level-1)}.day-cell[data-level="2"]{background-color:var(--level-2)}.day-cell[data-level="3"]{background-color:var(--level-3)}.day-cell[data-level="4"]{background-color:var(--level-4);box-shadow:0 0 8px var(--level-4)}.day-cell[data-has-todo=true]:after{content:"";position:absolute;top:-2px;right:-2px;width:5px;height:5px;background-color:#ef4444;border-radius:50%;box-shadow:0 0 0 1px var(--bg-card);z-index:5}.legend{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:1rem;font-size:12px;color:var(--text-muted)}.legend-item{width:10px;height:10px;border-radius:2px}.day-cell[data-weekend=true]{box-shadow:inset 0 0 0 1px #22d3ee80}.day-cell[data-holiday]{box-shadow:inset 0 0 0 1px #fbbf2480}.day-cell[data-today=true]{z-index:100!important;animation:pulse-today 2s infinite ease-in-out!important}@keyframes pulse-today{0%{box-shadow:inset 0 0 0 2px var(--today-border),0 0 2px 0 var(--today-glow);filter:brightness(100%)}50%{box-shadow:inset 0 0 0 2px var(--today-border),0 0 12px 3px var(--today-glow);filter:brightness(140%)}to{box-shadow:inset 0 0 0 2px var(--today-border),0 0 2px 0 var(--today-glow);filter:brightness(100%)}}.header-row{display:flex;gap:var(--cell-gap);align-items:center;margin-bottom:8px}.header-label{width:20px;margin-right:8px}.col-num{width:var(--cell-size);text-align:center;font-size:10px;color:var(--text-muted);font-family:monospace}.row-spacer{width:10px;margin-left:8px;flex-shrink:0}#app{width:100%;max-width:1280px;box-sizing:border-box;margin:0 auto;padding:2rem;position:relative;display:flex;flex-direction:column;align-items:center}#heatmap-section{display:flex;flex-direction:column;align-items:center}.mobile-only{display:none!important}.weight-shell{width:min(920px,100%);margin:0 auto;padding:88px 0 24px}.feature-header{text-align:left;margin-bottom:24px}.feature-header h1{margin-bottom:10px;color:var(--text-main);background:none;-webkit-background-clip:initial;background-clip:initial}.feature-copy{margin:0;color:var(--text-muted);max-width:560px}.weight-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}.summary-card,.weight-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:18px;box-shadow:0 10px 30px #00000014}.summary-card{padding:20px;text-align:left}.summary-label{color:var(--text-muted);font-size:.82rem;margin-bottom:10px}.summary-value{font-size:1.8rem;font-weight:700}.summary-value span{font-size:1rem;font-weight:500;color:var(--text-muted)}.summary-meta{margin-top:10px;color:var(--text-muted);font-size:.84rem}.summary-user-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:10px 0}.summary-user-row+.summary-user-row{border-top:1px dashed var(--border-color)}.summary-user-label{color:var(--text-muted);font-size:.88rem;white-space:nowrap}.summary-user-main{text-align:right}.summary-user-value{font-size:1.2rem;font-weight:700}.summary-user-value span{font-size:.9rem;font-weight:500;color:var(--text-muted)}.summary-user-meta{margin-top:4px;color:var(--text-muted);font-size:.78rem}.weight-card{padding:20px;margin-bottom:18px}.weight-series-filters{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.series-filter{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border-color);border-radius:999px;background:transparent;color:var(--text-main);padding:10px 14px;cursor:pointer;transition:all .2s ease}.series-filter.active{border-color:var(--series-color);background:color-mix(in srgb,var(--series-color) 18%,transparent)}.series-dot{width:10px;height:10px;border-radius:999px;background:var(--series-color, var(--weekend-color));flex-shrink:0}.weight-chart-card{display:flex;flex-direction:column;gap:16px}.weight-chart-stage{background:var(--bg-body);border:1px solid var(--border-color);border-radius:16px;padding:18px;min-height:220px}.weight-chart-axis{display:flex;justify-content:space-between;color:var(--text-muted);font-size:.82rem;margin-bottom:14px}.weight-chart-empty{padding:28px 0;color:var(--text-muted);text-align:center}.section-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.section-head-actions{display:flex;align-items:center;gap:10px}.section-head h2{margin:0;font-size:1.05rem}.section-meta{color:var(--text-muted);font-size:.85rem}.section-action-btn{border:1px solid var(--border-color);background:transparent;color:var(--text-main);border-radius:999px;padding:6px 12px;cursor:pointer;font-size:.82rem}.weight-chart-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.weight-grid-column{border:1px dashed var(--border-color);border-radius:14px;padding:14px;background:color-mix(in srgb,var(--bg-card) 70%,transparent)}.weight-grid-title{display:flex;align-items:center;gap:8px;font-weight:600;margin-bottom:10px}.weight-grid-values{display:flex;flex-direction:column;gap:8px}.weight-grid-value,.weight-grid-placeholder{display:flex;justify-content:space-between;gap:8px;color:var(--text-muted);font-size:.85rem}.weight-grid-value strong{color:var(--text-main);font-size:.9rem}.series-summary-meta,.weight-record-meta{color:var(--text-muted);font-size:.82rem}.weight-list{display:flex;flex-direction:column;gap:12px}.weight-record{border-radius:14px;background:var(--bg-body);border:1px solid var(--border-color);overflow:hidden;border-left-width:4px}.weight-record.user1{border-left-color:#14b8a6;background:color-mix(in srgb,#14b8a6 8%,var(--bg-body))}.weight-record.user2{border-left-color:#f59e0b;background:color-mix(in srgb,#f59e0b 8%,var(--bg-body))}.weight-record-trigger{width:100%;border:none;background:transparent;display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 16px;text-align:left;cursor:pointer}.weight-record-main{display:flex;align-items:center;gap:12px}.weight-record-date{font-weight:600;margin-bottom:4px}.weight-record-note{color:var(--text-muted);font-size:.88rem}.weight-record-side{text-align:right;flex-shrink:0}.weight-record-value{font-weight:700;margin-bottom:6px;white-space:nowrap}.weight-source-tag{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:.76rem;line-height:1;border:1px solid var(--border-color)}.weight-source-tag.auto{color:#0f766e;background:#14b8a61f;border-color:#14b8a63d}.weight-source-tag.manual{color:#b45309;background:#f59e0b24;border-color:#f59e0b47}.weight-record-details{border-top:1px solid var(--border-color);padding:12px 16px 14px;background:color-mix(in srgb,var(--bg-card) 78%,transparent)}.weight-metrics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-top:12px}.weight-metric-item{border-radius:12px;background:var(--bg-body);border:1px solid var(--border-color);padding:10px 12px}.weight-metric-item span{display:block;color:var(--text-muted);font-size:.76rem;margin-bottom:6px}.weight-metric-item strong{font-size:.98rem}.weight-record-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.weight-action{border:1px solid var(--border-color);background:transparent;color:var(--text-color);cursor:pointer;font-size:.82rem;border-radius:999px;padding:4px 10px}.weight-action-danger{color:#ef4444;border-color:#ef44444d}#event-panel{background:var(--bg-card);border:1px solid var(--border-color);display:flex;flex-direction:column;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 12px #0000000d}@media(min-width:1000px){#event-panel{width:320px;height:600px;max-height:90vh;position:fixed;top:50%;transform:translateY(-50%);left:50%;margin-left:220px;border-radius:12px;z-index:10}#event-panel.hidden{display:none!important}#close-btn.mobile-only{display:block!important}}@media(min-width:800px)and (max-width:999px){#event-panel{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;height:600px;max-height:80vh;border-radius:12px;z-index:201;box-shadow:0 10px 30px #0000004d}#event-panel.hidden{display:none!important}#panel-overlay,#close-btn.mobile-only{display:block!important}}@media(max-width:799px){#app{width:100%;display:block;padding:.5rem;overflow-x:hidden}.mobile-only{display:block!important}.menu-toggle{top:12px;left:12px;width:44px;height:44px;border-radius:12px}.page-view{padding-top:52px}.weight-shell{padding-top:72px}.weight-summary,.weight-chart-grid{grid-template-columns:1fr}.weight-record{align-items:stretch}.weight-record-trigger{flex-direction:row;align-items:center;gap:12px}.weight-record-main,.weight-record-side{width:auto}.weight-record-main{min-width:0}.weight-record-side{text-align:right}.weight-metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}#panel-overlay{position:fixed;inset:0;background:#0009;z-index:200;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:1;transition:opacity .3s}#panel-overlay.hidden{opacity:0;pointer-events:none}#event-panel{position:fixed;z-index:201;bottom:0;left:0;right:0;width:100%;max-height:80vh;border-radius:16px 16px 0 0;transform:translateY(0);box-shadow:0 -4px 20px #0003;display:flex;flex-direction:column}#event-panel.hidden{transform:translateY(100%);opacity:0;pointer-events:none}}.panel-header{padding:16px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border-radius:12px 12px 0 0}.panel-header h2{margin:0;font-size:1.1rem;color:var(--text-main)}#close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer}#event-list{flex:1;overflow-y:auto;padding:16px;background:var(--bg-body)}.empty-state{text-align:center;color:var(--text-muted);font-size:.9em;margin-top:2rem}.panel-input-area{padding:16px;background:var(--bg-card);border-top:1px solid var(--border-color);border-radius:0 0 12px 12px;display:flex;gap:8px}#event-input{flex:1;padding:8px 12px;border-radius:6px;border:1px solid var(--border-color);background:var(--bg-body);color:var(--text-main);outline:none}#event-input:focus{border-color:var(--weekend-color)}#add-btn{padding:0 16px;background:var(--weekend-color);color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;font-size:.9em}#add-btn:hover{filter:brightness(110%)}.event-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;margin-bottom:8px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 1px 2px #0000000d}.delete-event{color:#ef4444;cursor:pointer;padding:4px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:translate(-50%,-40%)}to{opacity:1;transform:translate(-50%,-50%)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}#event-list-container{flex:1;overflow-y:auto;padding:16px;background:var(--bg-body)}.list-section{margin-bottom:24px}.section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px 4px}.event-group{display:flex;flex-direction:column;gap:8px;min-height:20px}.event-item{display:flex;align-items:center;gap:12px;padding:10px 12px;margin-bottom:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:6px;box-shadow:0 1px 2px #0000000d;transition:all .2s ease}.event-item:hover{transform:translateY(-1px);box-shadow:0 2px 5px #0000001a}.event-text{flex:1;font-size:.95rem;line-height:1.4;color:var(--text-main)}.event-checkbox{width:20px;height:20px;min-width:20px;border-radius:6px;border:2px solid var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;background:transparent}.event-checkbox:hover{border-color:var(--weekend-color);background:#22d3ee1a}.event-item.done{opacity:.6;background:var(--bg-body);border-color:transparent}.event-item.done .event-text{color:var(--text-muted)}.event-item.done .event-checkbox{background:var(--weekend-color);border-color:var(--weekend-color);position:relative}.event-item.done .event-checkbox:after{content:"";width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg);margin-top:-2px}.event-item.giveup{opacity:.4;background:transparent;border:1px dashed var(--border-color)}.event-item.giveup .event-text{text-decoration:line-through;color:var(--text-muted);font-style:italic}.event-item.giveup .event-checkbox{border-color:var(--border-color);background:transparent;cursor:not-allowed}.event-item.giveup .event-checkbox:after{display:none}.input-actions{display:flex;gap:6px}.action-btn{width:36px;height:36px;border:none;border-radius:6px;font-weight:700;font-size:1.1em;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#fff}#add-todo-btn{background:var(--weekend-color);color:#fff}#add-todo-btn:hover{filter:brightness(110%);box-shadow:0 0 8px var(--weekend-color)}#add-done-btn.done{background:var(--border-color);color:var(--text-main)}#add-done-btn.done:hover{background:var(--text-muted)}.app-logo{height:150px;width:auto;margin-bottom:0;will-change:filter;transition:filter .3s}.app-logo:hover{filter:drop-shadow(0 0 1em #22d3eeaa)}.logo-sway{animation:sway .4s ease-in-out}.logo-spin{animation:spin .8s ease-in-out}@keyframes sway{0%,to{transform:rotate(0)}25%{transform:rotate(-15deg)}75%{transform:rotate(15deg)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}#auth-modal{position:fixed;inset:0;background:var(--bg-body);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .5s ease}#auth-modal.hidden{opacity:0;pointer-events:none}.auth-container{text-align:center;width:90%;max-width:320px}.auth-logo{width:80px;height:auto;margin-bottom:1rem}.auth-container h2{margin-bottom:.5rem;color:var(--text-main)}.auth-container p{color:var(--text-muted);font-size:.9em;margin-bottom:2rem}#auth-input{width:100%;box-sizing:border-box;padding:12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-main);outline:none;font-size:1.1em;text-align:center;margin-bottom:1rem;transition:border-color .2s}#auth-input:focus{border-color:var(--weekend-color)}#auth-btn{width:100%;box-sizing:border-box;padding:12px;border-radius:8px;border:none;background:var(--weekend-color);color:#fff;font-weight:700;font-size:1.1em;cursor:pointer;transition:filter .2s}#auth-btn:hover{filter:brightness(110%)}#panel-emoji-input{width:36px;height:36px;border:1px dashed var(--border-color);background:transparent;color:var(--text-main);text-align:center;font-size:1.2rem;border-radius:6px;margin-right:12px;cursor:pointer;transition:all .2s;padding:0}#panel-emoji-input:focus{border-style:solid;border-color:var(--weekend-color);outline:none;background:var(--bg-card)}.day-cell{display:flex;align-items:center;justify-content:center;font-size:12px;overflow:visible}.cell-emoji{pointer-events:none;line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3))}@keyframes logo-rock{0%{transform:rotate(-10deg)}50%{transform:rotate(10deg)}to{transform:rotate(-10deg)}}header.loading{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2000;margin:0;width:max-content;pointer-events:none;transition:all .6s cubic-bezier(.34,1.56,.64,1)}header.loading .app-logo{animation:logo-rock .8s ease-in-out infinite;filter:drop-shadow(0 0 20px rgba(34,211,238,.8))}.hidden{opacity:0!important;visibility:hidden!important;transition:opacity .5s ease,visibility 0s .5s}#auth-modal:not(.hidden){opacity:1;visibility:visible;transition:opacity .5s ease}#content-area{transition:opacity .4s ease,transform .4s ease;opacity:1;transform:translateY(0);width:fit-content;max-width:100%;margin:0 auto}#content-area.hidden-loading{opacity:0;transform:translateY(20px);pointer-events:none}::-webkit-scrollbar{display:none}html,body{scrollbar-width:none;-ms-overflow-style:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}input,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}input[type=search]::-webkit-search-decoration,input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-results-button,input[type=search]::-webkit-search-results-decoration{-webkit-appearance:none;display:none}.edit-input{flex:1;font-size:.95rem;line-height:1.4;color:var(--text-main);background:transparent;border:none;border-bottom:1px solid var(--weekend-color);outline:none;padding:0;margin:0;font-family:inherit;width:100%}.sortable-ghost{opacity:.4;background-color:var(--border-color)}.sortable-drag{cursor:grabbing;opacity:1;background:var(--bg-card);box-shadow:0 5px 15px #0003;transform:scale(1.02)}
