:root{--intensity-0: #f0faf4;--intensity-25: #95d5b2;--intensity-50: #52b788;--intensity-75: #2d6a4f;--intensity-100: #1b4332;--bg-primary: #fafffe;--bg-secondary: #f0faf4;--bg-header: #ffffff;--text-primary: #1a2e22;--text-secondary: #3a6647;--text-muted: #7aaa8a;--text-on-dark: #f0faf4;--border-color: #d4eddb;--border-subtle: #e8f5ec;--accent: #2d6a4f;--accent-hover: #1b4332;--accent-light: #d4eddb;--today-bg: #c8e6d0;--day-number-color: #b8b8b8;--day-number-today: #555;--day-badge-color: #c0c0c0;--day-badge-bg: rgba(0, 0, 0, .04);--day-badge-border: rgba(0, 0, 0, .1);--shadow-sm: 0 1px 3px rgba(27, 67, 50, .08);--shadow-md: 0 4px 12px rgba(27, 67, 50, .12);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}[data-theme=dark]{--intensity-0: #1a2e22;--intensity-25: #2d5a3d;--intensity-50: #3a7d55;--intensity-75: #52b788;--intensity-100: #95d5b2;--bg-primary: #0f1f16;--bg-secondary: #1a2e22;--bg-header: #142218;--text-primary: #e8f5ec;--text-secondary: #95d5b2;--text-muted: #52b788;--text-on-dark: #1a2e22;--border-color: #2d5a3d;--border-subtle: #1f3d2b;--accent: #52b788;--accent-hover: #95d5b2;--accent-light: #1f3d2b;--today-bg: #2d5a3d;--day-number-color: #5a5a5a;--day-number-today: #d0d0d0;--day-badge-color: #666;--day-badge-bg: rgba(255, 255, 255, .05);--day-badge-border: rgba(255, 255, 255, .12);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-optical-sizing:auto;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100dvh;transition:background-color .2s ease,color .2s ease;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;flex-direction:column;min-height:100dvh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none}input{font-family:inherit}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--radius-sm)}.app-layout{display:flex;flex-direction:column;min-height:100dvh;max-width:100%}.app-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--bg-header);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100}.app-header-left{display:flex;align-items:center;gap:8px}.app-logo{display:inline-flex;align-items:center;gap:.375rem;font-size:1.125rem;font-weight:700;letter-spacing:-.02em;color:var(--accent);text-decoration:none}.app-logo-icon{width:1.375rem;height:1.375rem;flex-shrink:0}.app-logo:hover{text-decoration:none;opacity:.8}.app-header-actions{display:flex;align-items:center;gap:8px}.app-main{flex:1;padding:16px;display:flex;flex-direction:column;align-items:center;gap:16px}.grid-intro{max-width:560px;width:100%;font-size:.8125rem;color:#555;line-height:1.6;text-align:left}.grid-intro strong{color:var(--text-secondary);font-weight:600}.app-footer{padding:12px 16px;font-size:.75rem;color:var(--text-muted);text-align:center;border-top:1px solid var(--border-subtle)}.app-footer a{padding:0 8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border-radius:var(--radius-md);font-size:.7rem;font-weight:500;line-height:1;transition:background-color .12s ease,color .12s ease,opacity .12s ease;white-space:nowrap}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn-ghost:hover{background:var(--bg-secondary)}.btn-icon{padding:6px;border-radius:var(--radius-sm);color:var(--text-muted)}.btn-icon:hover{background:var(--bg-secondary);color:var(--text-primary)}svg{flex-shrink:0}.page-layout{display:flex;flex-direction:column;min-height:100dvh}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;background:var(--bg-header);border-bottom:1px solid var(--border-subtle)}.page-header-left{display:flex;align-items:center;gap:16px}.page-nav{display:flex;gap:12px;font-size:.8125rem;color:var(--text-secondary)}.page-content{flex:1;max-width:720px;width:100%;margin:0 auto;padding:32px 16px 48px}.page-content h1{font-size:1.75rem;font-weight:700;letter-spacing:-.03em;color:var(--text-primary);margin-bottom:8px}.page-content .page-subtitle{font-size:.9375rem;color:var(--text-muted);margin-bottom:32px}.page-content h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-top:32px;margin-bottom:12px}.page-content p{color:var(--text-secondary);margin-bottom:12px;font-size:.9375rem;line-height:1.65}.page-content ul,.page-content ol{color:var(--text-secondary);font-size:.9375rem;line-height:1.65;padding-left:20px;margin-bottom:12px}.page-content li{margin-bottom:4px}.view-filter{display:flex;background:var(--bg-secondary);border-radius:var(--radius-md);padding:3px;gap:2px;width:100%;max-width:680px}.view-filter-btn{flex:1;padding:7px 0;border-radius:calc(var(--radius-md) - 2px);font-size:.8125rem;font-weight:500;color:var(--text-muted);transition:background .15s ease,color .15s ease,box-shadow .15s ease;cursor:pointer}.view-filter-btn.active{background:var(--bg-primary);color:var(--text-primary);box-shadow:0 1px 3px #0000001f}.view-filter-btn:hover:not(.active){color:var(--text-secondary)}.time-nav{display:flex;align-items:center;justify-content:center;gap:10px;padding:4px 0 8px;width:100%;max-width:680px}.time-nav-label{font-size:.875rem;font-weight:600;letter-spacing:-.01em;color:var(--text-primary);min-width:200px;text-align:center;-webkit-user-select:none;user-select:none}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.grid-outer{width:100%;max-width:680px;margin:0 auto}.grid-export-wrapper{background:var(--bg-primary);padding:16px 0 12px;border-radius:var(--radius-lg)}.export-month-label{font-size:.75rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:0 4px 10px;text-align:center;display:none}.grid-with-label{display:flex;flex-direction:row;align-items:stretch}.grid-left-col{display:flex;flex-direction:column;flex-shrink:0;align-self:stretch}.grid-left-header{height:calc(20px + 1.65rem);display:flex;align-items:center;justify-content:center;flex-shrink:0}.days-month-label{writing-mode:vertical-lr;transform:rotate(180deg);font-size:.55rem;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:#aaa;opacity:.8;display:flex;align-items:center;justify-content:center;padding:0 3px;-webkit-user-select:none;user-select:none;flex:1}.grid-scroll-wrapper{flex:1;overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.grid-scroll-wrapper::-webkit-scrollbar{height:4px}.grid-scroll-wrapper::-webkit-scrollbar-track{background:transparent}.grid-scroll-wrapper::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.habit-grid{padding:10px 0;display:flex;flex-direction:column;gap:5px;min-width:100%}.habit-grid-row{display:flex;gap:5px;align-items:center}.habit-grid-corner{width:24px;flex-shrink:0;padding-bottom:6px}.day-number{position:relative;display:flex;align-items:center;justify-content:flex-end;padding-right:5px;font-size:.625rem;font-weight:500;color:var(--day-number-color);width:24px;flex-shrink:0;-webkit-user-select:none;user-select:none;letter-spacing:0}.day-number.today{color:var(--day-number-today);font-weight:700}.day-number.sunday{flex-direction:column;justify-content:center;align-items:center;padding-right:0;gap:2px}.day-number.sunday:before{content:"sun";position:static;right:auto;top:auto;transform:none;order:2;font-size:.42rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--day-badge-color);white-space:nowrap;line-height:1;background:var(--day-badge-bg);border:1px solid var(--day-badge-border);border-radius:3px;padding:1px 2px}.sunday-divider{width:100%;height:1px;background:var(--border-color);opacity:.4;margin-block:8px}.grid-legend{display:flex;align-items:center;gap:12px;padding:20px 4px 2px;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:4px}.legend-swatch{display:block;width:10px;height:10px;border-radius:2px;flex-shrink:0}.legend-swatch.intensity-0{background:var(--intensity-0);border:1px solid var(--border-color)}.legend-swatch.intensity-25{background:var(--intensity-25)}.legend-swatch.intensity-50{background:var(--intensity-50)}.legend-swatch.intensity-75{background:var(--intensity-75)}.legend-swatch.intensity-100{background:var(--intensity-100)}.legend-label{font-size:.625rem;color:var(--text-muted);font-weight:500}.watermark{margin-left:auto;font-size:.625rem;color:var(--text-muted);opacity:.6;-webkit-user-select:none;user-select:none}.first-visit-tooltip{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;background:var(--accent);color:#fff;border-radius:var(--radius-md);font-size:.8125rem;font-weight:500;animation:slideDown .2s ease both;margin-bottom:8px}.first-visit-tooltip button{color:#fffc;font-size:1rem;line-height:1;padding:0 2px;flex-shrink:0}.first-visit-tooltip button:hover{color:#fff}.add-habit-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex-shrink:0;background:transparent;border:1.5px dashed var(--border-color);border-radius:var(--radius-sm);color:var(--text-muted);font-size:1rem;font-weight:400;cursor:pointer;transition:border-color .12s ease,color .12s ease,background .12s ease}.add-habit-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.habit-grid .day-number,.habit-grid .day-cell{animation:fadeInRow .2s ease both}@keyframes fadeInRow{0%{opacity:0}to{opacity:1}}:root{--cell-h-mobile: 32px;--cell-h-desktop: 24px}.day-cell{display:flex;align-items:center;justify-content:center;height:var(--cell-h-mobile);flex:1 0 93px;border-radius:var(--radius-sm);cursor:pointer;position:relative;transition:background-color .12s ease,transform 80ms ease;outline:none;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.cell-intensity-label{font-size:.5rem;font-weight:700;color:#ffffffd9;line-height:1;pointer-events:none;letter-spacing:-.01em}.day-cell:focus-visible{outline:2px solid var(--accent);outline-offset:1px;z-index:1}.day-cell.intensity-0{background:var(--intensity-0);border:1px solid var(--border-color)}.day-cell.intensity-25{background:var(--intensity-25);border:1px solid transparent}.day-cell.intensity-50{background:var(--intensity-50);border:1px solid transparent}.day-cell.intensity-75{background:var(--intensity-75);border:1px solid transparent}.day-cell.intensity-100{background:var(--intensity-100);border:1px solid transparent}.day-cell.today.intensity-0{background:var(--today-bg);border-color:transparent}.day-cell.future{background:var(--bg-secondary)!important;border-color:var(--border-subtle)!important;cursor:default;opacity:.4;pointer-events:none}.day-cell:not(.future):active{transform:scale(.9)}@media (min-width: 768px){.day-cell{height:var(--cell-h-desktop)}}.habit-header-cell{display:flex;flex-direction:column;align-items:center;gap:4px;padding:2px 0 6px;position:relative;flex:1 0 93px;cursor:grab;touch-action:none}.habit-header-cell:active{cursor:grabbing}.habit-header-cell[data-is-dragging=true]{opacity:.4}.habit-name-wrapper{display:flex;align-items:center;justify-content:center;width:100%;min-width:0}.habit-name{font-size:.75rem;font-weight:600;color:var(--text-secondary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;letter-spacing:.01em;cursor:pointer;padding:2px 3px;border-radius:3px;transition:background .1s ease;line-height:1.3}.habit-name:hover{background:var(--accent-light);color:var(--accent)}.habit-name-input{font-size:.75rem;font-weight:600;color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--accent);border-radius:3px;padding:2px 4px;width:100%;min-width:0;text-align:center;outline:none;letter-spacing:.01em}.habit-menu-container{width:100%;display:flex;justify-content:center}.habit-menu-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:2px 0 3px;cursor:pointer;font-size:.75rem;font-weight:700;letter-spacing:.2em;color:var(--text-secondary);opacity:.55;transition:opacity .1s ease,background .1s ease;border-radius:3px;line-height:1}.habit-menu-btn:hover,.habit-header-cell:hover .habit-menu-btn{opacity:1;background:var(--bg-secondary)}.habit-context-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--bg-header);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:6px;box-shadow:var(--shadow-md);z-index:200;display:flex;flex-direction:column;gap:5px;animation:slideDown .15s ease both}.habit-menu-move-row{display:flex;gap:4px}.habit-menu-drag-hint{font-size:.625rem;font-weight:500;color:var(--text-muted);text-align:center;letter-spacing:.05em;padding:2px 0;opacity:.7}.habit-menu-delete-btn{padding:5px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;color:#dc2626;background:transparent;text-align:center;transition:background .1s ease}.habit-menu-delete-btn:hover{background:#fee2e2}.habit-menu-confirm-label{font-size:.6875rem;color:var(--text-secondary);font-weight:500;text-align:center;padding:2px 4px}.habit-menu-confirm-yes{flex:1;padding:5px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;background:#dc2626;color:#fff;transition:background .1s ease}.habit-menu-confirm-yes:hover{background:#b91c1c}.habit-menu-confirm-no{flex:1;padding:5px 8px;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;background:var(--bg-secondary);color:var(--text-secondary);border:1px solid var(--border-color);transition:background .1s ease}.habit-menu-confirm-no:hover{background:var(--border-color)}
