html,body,#root{margin:0;width:100%;min-height:100%}body{min-width:320px}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-ext-400-normal-BQZuk6qB.woff2) format("woff2"),url(/assets/inter-cyrillic-ext-400-normal-DQukG94-.woff) format("woff");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-cyrillic-400-normal-obahsSVq.woff2) format("woff2"),url(/assets/inter-cyrillic-400-normal-HOLc17fK.woff) format("woff");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-ext-400-normal-DGGRlc-M.woff2) format("woff2"),url(/assets/inter-greek-ext-400-normal-KugGGMne.woff) format("woff");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-greek-400-normal-B4URO6DV.woff2) format("woff2"),url(/assets/inter-greek-400-normal-q2sYcFCs.woff) format("woff");unicode-range:U+0370-0377,U+037A-037F,U+0384-038A,U+038C,U+038E-03A1,U+03A3-03FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-vietnamese-400-normal-DMkecbls.woff2) format("woff2"),url(/assets/inter-vietnamese-400-normal-Bbgyi5SW.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-ext-400-normal-C1nco2VV.woff2) format("woff2"),url(/assets/inter-latin-ext-400-normal-77YHD8bZ.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/inter-latin-400-normal-C38fXH4l.woff2) format("woff2"),url(/assets/inter-latin-400-normal-CyCys3Eg.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Patrick Hand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/patrick-hand-vietnamese-400-normal-65jA92mZ.woff2) format("woff2"),url(/assets/patrick-hand-vietnamese-400-normal-CZjY324Y.woff) format("woff");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+0300-0301,U+0303-0304,U+0308-0309,U+0323,U+0329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Patrick Hand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/patrick-hand-latin-ext-400-normal-Dno5CMlI.woff2) format("woff2"),url(/assets/patrick-hand-latin-ext-400-normal-C2ywpnn3.woff) format("woff");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Patrick Hand;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/patrick-hand-latin-400-normal-B7HHA2Vw.woff2) format("woff2"),url(/assets/patrick-hand-latin-400-normal-Df9_VoRQ.woff) format("woff");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--bg: #f7f5ef;--surface: #fffdf8;--text: #1f1f1f;--muted: #5f5f5f;--border: #1f1f1f;--accent: #3b82f6;--positive: #1f7a3f;--negative: #b42318;--row-hover: rgba(31, 31, 31, .1);--font-patrick-hand: "Patrick Hand", "Comic Sans MS", cursive;--font-cascadia-code: "Cascadia Code", "Cascadia Mono", "Consolas", "Courier New", monospace;--app-font-family: var(--font-patrick-hand)}:root[data-theme=dark]{--bg: #161616;--surface: #202020;--text: #f3f3f3;--muted: #b8b8b8;--border: #f3f3f3;--accent: #7db7ff;--positive: #5dd39e;--negative: #ff8a80;--row-hover: rgba(243, 243, 243, .12)}:root[data-font=patrick-hand]{--app-font-family: var(--font-patrick-hand)}:root[data-font=cascadia-code]{--app-font-family: var(--font-cascadia-code)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:var(--app-font-family)}button,input,select,textarea{font-family:inherit}.app{max-width:1400px;margin:0 auto;padding:12px 12px 230px}.hand{font-family:var(--app-font-family)}.title{margin:0;font-size:clamp(2rem,4vw,3rem);line-height:1}.header{display:flex;flex-direction:column;align-items:stretch;gap:12px;margin-bottom:18px}.header-main{display:flex;flex-direction:column;gap:8px}.workspace-field-wrap{position:relative;width:min(360px,100%)}.workspace-field-inline{width:100%;min-width:0}.workspace-field-label{font-size:.82rem;color:var(--muted);margin-bottom:2px;padding-left:2px}.workspace-field-trigger{width:100%;min-height:32px;border:0;background:color-mix(in srgb,var(--surface) 90%,transparent);color:var(--text);border-radius:8px;display:inline-flex;align-items:center;justify-content:space-between;gap:8px;padding:5px 10px;font-size:.95rem}.workspace-field-trigger:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 62%,transparent);outline-offset:2px}.workspace-field-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.workspace-field-trigger .collapse-chevron{opacity:.7}.workspace-field-inline .workspace-field-label{display:none}.workspace-field-inline .workspace-field-trigger{min-height:50px;padding:0 10px}.workspace-field-inline .workspace-popover{left:auto;right:0;width:max(100%,250px);max-width:min(340px,calc(100vw - 24px))}.workspace-popover{position:absolute;top:calc(100% + 6px);left:0;z-index:45;width:min(440px,calc(100vw - 24px));max-height:72vh;overflow:auto;background:var(--surface);border:1px solid color-mix(in srgb,var(--border) 30%,transparent);border-radius:10px;box-shadow:0 10px 24px #00000024;padding:8px;display:flex;flex-direction:column;gap:8px}.workspace-popover-header{display:inline-flex;align-items:center;gap:8px;padding:2px 2px 0;color:var(--muted)}.workspace-popover-title{font-size:.82rem;font-weight:600;text-transform:none;letter-spacing:.01em}.workspace-popover-info{position:relative;width:16px;height:16px;border:1px solid color-mix(in srgb,var(--border) 45%,transparent);border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;line-height:1;cursor:help;-webkit-user-select:none;user-select:none}.workspace-popover-info:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 62%,transparent);outline-offset:2px}.workspace-list{display:flex;flex-direction:column;gap:6px}.workspace-row{display:block}.workspace-row-main{min-height:34px;border:1px solid color-mix(in srgb,var(--border) 28%,transparent);border-radius:8px;background:transparent;color:var(--text);padding:0 4px 0 10px;font-size:.95rem;display:flex;align-items:center;gap:4px}.workspace-row-select{flex:1;min-width:0;min-height:32px;border:0;background:transparent;color:inherit;text-align:left;padding:0;font-size:inherit;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.workspace-row-select:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 70%,transparent);outline-offset:2px;border-radius:6px}.workspace-row.is-active .workspace-row-main{border-color:color-mix(in srgb,var(--accent) 65%,var(--border));background:color-mix(in srgb,var(--accent) 18%,transparent)}.workspace-row.is-renaming .workspace-row-actions{opacity:1;transform:none;pointer-events:auto}.workspace-row.is-renaming .workspace-row-main{gap:8px}.workspace-row.is-renaming .workspace-row-main:focus-within{border-color:color-mix(in srgb,var(--accent) 65%,var(--border));box-shadow:0 0 0 2px color-mix(in srgb,var(--accent) 18%,transparent)}.workspace-row-rename-input{flex:1;min-width:0;min-height:28px;border-width:1px;border-radius:6px;padding:4px 8px;font-size:.92rem}.workspace-row.is-renaming .workspace-row-rename-input{min-height:32px;border:0;border-radius:0;background:transparent;padding:0;font-size:inherit}.workspace-row.is-renaming .workspace-row-rename-input:focus{outline:none}.workspace-row-action{width:24px;height:24px;border:0;border-radius:8px;background:transparent;color:var(--muted);padding:0;display:inline-flex;align-items:center;justify-content:center;transition:background-color .14s ease,color .14s ease,transform .14s ease}.workspace-row-action-edit{width:24px;height:24px}.workspace-row-action-save{width:auto;min-width:58px;padding:0 10px;border-radius:7px;font-size:.78rem;line-height:1;letter-spacing:.01em}.workspace-row-actions{display:inline-flex;gap:2px;opacity:0;transform:translate(2px);pointer-events:none;transition:opacity .14s ease,transform .14s ease}.workspace-row:hover .workspace-row-actions,.workspace-row:focus-within .workspace-row-actions{opacity:1;transform:translate(0);pointer-events:auto}.workspace-row-action-icon{width:13px;height:13px;display:block}.workspace-row-danger{color:var(--negative)}.workspace-row-action:hover{background:color-mix(in srgb,var(--row-hover) 45%,transparent);color:var(--text);transform:translateY(-1px)}.workspace-row-action-save:hover{background:color-mix(in srgb,var(--positive) 16%,transparent);color:var(--positive)}.workspace-row-action:focus-visible{outline:2px solid color-mix(in srgb,var(--accent) 62%,transparent);outline-offset:1px}.workspace-row-danger:hover{background:color-mix(in srgb,var(--negative) 12%,transparent);color:var(--negative)}@media(hover:none){.workspace-row-actions{opacity:1;transform:none;pointer-events:auto}}.workspace-create-toggle{min-height:34px;border:0!important;border-radius:8px;background:transparent;color:var(--muted);text-align:left;padding:0 10px;font-size:.9rem;appearance:none;-webkit-appearance:none}.workspace-create-row{display:block}.workspace-create-input-wrap{position:relative}.workspace-create-input{width:100%;min-height:34px;padding:6px 78px 6px 8px;font-size:.95rem}.workspace-create-btn{position:absolute;top:50%;right:4px;transform:translateY(-50%)}.workspace-create-btn:hover{transform:translateY(calc(-50% - 1px))}.workspace-create-save{width:auto;min-width:58px;padding:0 10px;border-radius:7px;color:inherit;font-size:.78rem;line-height:1;letter-spacing:.01em}.workspace-create-save:hover{background:color-mix(in srgb,var(--positive) 16%,transparent);color:var(--positive)}.workspace-error{color:var(--negative);font-size:.84rem;line-height:1.25}.google-sync-hint{align-self:center;margin-inline:auto;display:inline-flex;align-items:center;gap:8px;margin-top:-4px;padding:4px 10px;border-radius:999px;border:1px dashed color-mix(in srgb,var(--border) 24%,transparent);background:color-mix(in srgb,var(--surface) 86%,transparent);color:var(--muted);font-size:.92rem;line-height:1.15;animation:google-hint-enter .22s ease-out}.google-sync-icon{display:inline-block;width:14px;text-align:center;transform-origin:center}.google-sync-hint.status-pending .google-sync-icon{animation:google-icon-wait .9s ease-in-out infinite}.google-sync-hint.status-saving .google-sync-icon{animation:google-icon-upload .85s linear infinite}.google-sync-hint.status-saved{color:var(--positive);border-color:color-mix(in srgb,var(--positive) 40%,transparent)}.google-sync-hint.status-error{color:var(--negative);border-color:color-mix(in srgb,var(--negative) 45%,transparent)}.google-sync-text{white-space:nowrap}@keyframes google-hint-enter{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}@keyframes google-icon-upload{0%{transform:translateY(5px);opacity:.45}40%{opacity:1}to{transform:translateY(-5px);opacity:.4}}@keyframes google-icon-wait{0%,to{opacity:.35}50%{opacity:1}}.header-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.header-actions>.sketch-btn,.header-actions>label.sketch-btn{width:100%!important;min-width:0;height:46px!important;padding:0!important;display:inline-flex!important;align-items:center!important;justify-content:center!important}.header-actions>.header-menu-wrap{width:100%;min-width:0;position:relative}.header-menu-toggle{width:100%;height:46px;padding:0;display:inline-flex;align-items:center;justify-content:center;font-size:1.25rem;line-height:1}.header-menu-panel{position:absolute;right:0;top:calc(100% + 8px);z-index:40;width:min(300px,calc(100vw - 24px));background:var(--surface);border:1px solid color-mix(in srgb,var(--border) 35%,transparent);border-radius:10px;box-shadow:0 10px 24px #00000024;padding:6px;display:flex;flex-direction:column;gap:4px}.header-menu-item{border:1px solid transparent;background:transparent;color:var(--text);border-radius:8px;min-height:38px;padding:0 10px;display:inline-flex;align-items:center;justify-content:flex-start;text-align:left;font-size:1.08rem;gap:10px;cursor:pointer}.header-menu-item-icon{width:1.3em;text-align:center;opacity:.9}.header-menu-item:hover{background:color-mix(in srgb,var(--row-hover) 45%,transparent);border-color:color-mix(in srgb,var(--border) 30%,transparent)}.header-menu-item:disabled{opacity:.45;cursor:not-allowed}.header-menu-item:disabled:hover{background:transparent;border-color:transparent}.header-menu-item.danger{color:var(--negative)}.header-menu-file{position:relative;overflow:hidden}.header-menu-file input{position:absolute;inset:0;opacity:0;cursor:pointer}.header-menu-group{border:1px solid color-mix(in srgb,var(--border) 18%,transparent);border-radius:8px;overflow:hidden;background:color-mix(in srgb,var(--surface) 86%,transparent)}.header-menu-group-toggle{width:100%}.header-menu-group-chevron{margin-left:auto;transition:transform .2s ease;opacity:.72}.header-menu-group.is-open .header-menu-group-chevron{transform:rotate(180deg)}.header-menu-group-body{padding:2px 4px 6px;display:flex;flex-direction:column;gap:4px;border-top:1px dashed color-mix(in srgb,var(--border) 16%,transparent)}.header-menu-group-body .header-menu-item{min-height:34px;font-size:1rem}.header-menu-group-body .header-menu-status{margin-top:2px;padding:4px 8px 0}.header-menu-status{margin-top:3px;padding:6px 10px 2px;font-size:.9rem;color:var(--muted)}.header-menu-status.is-connected{color:var(--positive)}.header-menu-status-line{line-height:1.25}.header-menu-status-line+.header-menu-status-line{margin-top:2px}.header-menu-status-line.auto-backup-pending,.header-menu-status-line.auto-backup-saving{color:var(--muted)}.header-menu-status-line.auto-backup-saved{color:var(--positive)}.header-menu-status-line.auto-backup-error,.header-menu-status-line.auto-backup-error-detail{color:var(--negative)}.header-menu-status-line.auto-backup-error-detail{font-size:.8rem;overflow-wrap:anywhere}.header-balance{grid-column:1 / -1}.header-balance-toggle{cursor:pointer;width:100%;border:2px solid var(--border);position:relative;transition:transform .16s ease,background-color .2s ease}.header-balance-toggle:hover{transform:translateY(-1px);background:color-mix(in srgb,var(--row-hover) 55%,var(--surface))}.header-balance-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.header-balance-value{font-size:1.2rem}.header-balance-click-hint{position:absolute;right:6px;bottom:4px;color:var(--text);opacity:.58;pointer-events:none;transition:transform .16s ease,opacity .2s ease}.header-balance-click-icon{width:15px;height:15px;display:block}.header-balance-toggle:hover .header-balance-click-hint,.header-balance-toggle:focus-visible .header-balance-click-hint{transform:translateY(-1px) scale(1.04);opacity:.9}.year-group{margin-bottom:28px}.year-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;padding-bottom:8px}.year-title{margin:0;font-size:1.22rem;letter-spacing:.06em;font-weight:700}.year-content{padding-left:10px}.month-group{margin-bottom:20px}.month-header{display:flex;align-items:center;gap:6px;margin-bottom:8px}.month-title{margin:0;font-size:1rem;font-weight:600;letter-spacing:.02em;text-transform:none}.month-sort-controls{display:flex;align-items:center;gap:6px}.year-sort-controls{margin-left:2px}.month-view-controls{display:flex;align-items:center;margin-left:auto}.month-sort-btn{border:1px dashed color-mix(in srgb,var(--border) 45%,transparent);background:transparent;color:var(--muted);border-radius:999px;height:28px;padding:0 10px;font-size:.82rem;cursor:pointer;display:inline-flex;align-items:center;gap:6px;line-height:1}.month-sort-btn:hover{color:var(--text);border-color:color-mix(in srgb,var(--border) 70%,transparent)}.month-view-mode-btn{height:30px;gap:2px;padding:2px;border-style:solid;border-color:color-mix(in srgb,var(--border) 30%,transparent);cursor:default}.month-view-option{border:none;background:transparent;font-family:inherit;cursor:pointer;border-radius:999px;padding:4px 8px;font-size:.76rem;line-height:1;color:var(--muted)}.month-view-option:hover{color:var(--text)}.month-view-option.is-active{background:color-mix(in srgb,var(--row-hover) 75%,transparent);color:var(--text)}.plain-list-head{display:none}.month-collapse-btn{width:28px;min-width:28px;height:28px;padding:0;justify-content:center;border-style:solid;border-color:color-mix(in srgb,var(--border) 25%,transparent);background:transparent}.year-collapse-btn{border-color:color-mix(in srgb,var(--border) 36%,transparent)}.collapse-chevron{display:inline-block;font-size:1.08rem;line-height:1;transition:transform .2s ease}.month-collapse-btn.is-collapsed .collapse-chevron{transform:rotate(-90deg)}.sort-icon-pair{display:inline-flex;align-items:center;gap:2px}.sort-arrow{opacity:.32;transition:opacity .2s ease,color .2s ease}.sort-arrow.is-active{opacity:.95;color:var(--text);font-weight:700}.days-wrapper{width:100%;max-width:1040px;margin:0 auto}.days-wrapper.sort-transition .month-group{animation:sort-fade-in .42s cubic-bezier(.16,1,.3,1) both;animation-delay:var(--sort-delay, 0ms);will-change:transform,opacity,filter}.days-wrapper.sort-transition .day-row{animation:sort-row-in .38s cubic-bezier(.16,1,.3,1) both;animation-delay:calc(var(--sort-delay, 0ms) + 70ms);will-change:transform,opacity,filter}@keyframes sort-fade-in{0%{opacity:0;transform:translateY(14px) scale(.992);filter:blur(2px)}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}}@keyframes sort-row-in{0%{opacity:0;transform:translateY(10px);filter:blur(1px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}@media(prefers-reduced-motion:reduce){.days-wrapper.sort-transition .month-group,.days-wrapper.sort-transition .day-row{animation:none}}.day-row{display:grid;grid-template-columns:1fr;gap:8px;margin-bottom:10px;padding:10px;border:1px solid color-mix(in srgb,var(--border) 24%,transparent);border-radius:12px;background:color-mix(in srgb,var(--surface) 90%,transparent);transition:background-color .2s ease}.day-row:hover,.day-row:focus-within{background:var(--row-hover)}.day-row.weekend-empty{opacity:.4;border:1px dashed var(--border);filter:grayscale(.5)}.day-row.weekend-empty .day-stats-column{min-height:50px}.day-row.weekend-empty .punches-block{min-height:50px;align-items:center}.day-row.weekend-empty .add-punch-btn{align-self:center}.missing-day-row{opacity:.32;border:none;padding:0 10px;gap:4px;min-height:0;align-items:center;margin-bottom:0}.missing-day-row:hover,.missing-day-row:focus-within{opacity:.62}.missing-day-stats{display:none}.missing-day-date-slot{width:100%;min-height:0;display:flex;align-items:center;justify-content:flex-start;gap:6px;padding:0 4px}.missing-day-date-text{color:var(--muted);font-size:.74rem;letter-spacing:.02em;line-height:1}.missing-day-weekday{opacity:0;border-color:transparent;min-height:0;height:0;overflow:hidden}.missing-day-tail{display:none}.missing-day-actions-spacer{min-height:0;flex-shrink:0}.missing-day-row .missing-day-inline-add-btn{border-radius:3px;width:16px;min-height:16px;height:16px;padding:0;transform:rotate(45deg);opacity:0;pointer-events:none;transition:opacity .2s ease}.missing-day-inline-add-btn span{display:block;width:8px;height:8px;font-size:0;transform:rotate(-45deg);position:relative}.missing-day-inline-add-btn span:before,.missing-day-inline-add-btn span:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:currentColor;border-radius:999px}.missing-day-inline-add-btn span:before{width:8px;height:1.4px}.missing-day-inline-add-btn span:after{width:1.4px;height:8px}.missing-day-row:hover .missing-day-inline-add-btn,.missing-day-row:focus-within .missing-day-inline-add-btn{opacity:.45;pointer-events:auto}.missing-day-row.menu-open{opacity:1;z-index:100;position:relative}.missing-day-type-picker{position:relative;display:inline-flex}.missing-day-type-menu{position:absolute;top:calc(100% + 4px);left:0;display:flex;flex-direction:column;min-width:100px;padding:4px;border-radius:6px;border:1px solid var(--border);background:var(--bg);box-shadow:0 4px 12px #00000026;z-index:100}.missing-day-type-option{all:unset;cursor:pointer;padding:4px 10px;font-size:.78rem;color:var(--text);border-radius:4px;line-height:1.5}.missing-day-type-option:hover{background:var(--row-hover)}.day-stats-column{width:100%}.stats-block{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;width:100%}.stats-block.no-goal{grid-template-columns:repeat(3,minmax(0,1fr))}.stat-box{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:4px 8px;text-align:center;display:flex;flex-direction:column;justify-content:center;min-height:50px}.stat-box label{font-size:.7rem;text-transform:uppercase;color:var(--muted);font-family:var(--app-font-family)}.stat-box strong{font-size:1.1rem;font-family:inherit}.stat-box-trab-tip{position:relative;cursor:default}.stat-box-trab-tip:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);min-width:150px;max-width:220px;padding:6px 10px;border-radius:8px;border:1px solid color-mix(in srgb,var(--border) 24%,transparent);background:color-mix(in srgb,var(--surface) 96%,transparent);color:var(--text);font-size:.72rem;line-height:1.4;text-align:left;white-space:pre-line;box-shadow:0 6px 16px #0000001f;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:12}.stat-box-trab-tip:hover:after,.stat-box-trab-tip:focus-visible:after{opacity:1}.goal-input{border:none;background:transparent;color:inherit;font-family:inherit;font-size:1.1rem;font-weight:700;text-align:center;width:100%;padding:0;margin:0;cursor:pointer}.exit-suggestion-text{margin-top:4px;font-size:.75rem;color:var(--muted);text-align:left;padding-left:4px;opacity:.8}.exit-suggestion-text strong{font-family:inherit;color:var(--text);font-size:.9rem}.date-block{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:4px 8px;display:flex;align-items:center;justify-content:center;width:100%;min-height:50px}.date-input{width:100%;border:none;background:transparent;color:var(--text);font-family:inherit;font-size:1rem}.desktop-widgets-rail,.desktop-today-clock,.desktop-weather-widget{display:none}.weekday-pill{font-size:.75rem;color:var(--muted);opacity:.75;border:1px dashed color-mix(in srgb,var(--border) 35%,transparent);border-radius:999px;width:fit-content;padding:3px 8px}.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.85}:root[data-theme=dark] .date-input::-webkit-calendar-picker-indicator{filter:invert(1) brightness(1.15);opacity:.95}.punches-block{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:start}.punch-wrapper{position:relative;display:flex;align-items:center}.punch-pair{display:flex;gap:4px;align-items:center}.punch-input{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:4px 6px;width:100%;text-align:center;color:var(--text);font-family:inherit;font-size:1rem;min-height:50px;font-variant-numeric:tabular-nums}.punch-input::placeholder{font-family:var(--font-cascadia-code);font-size:.8rem;letter-spacing:0;line-height:1;opacity:.75}.punch-input::-webkit-calendar-picker-indicator,.goal-input::-webkit-calendar-picker-indicator{display:none;-webkit-appearance:none}.delete-punch-btn{position:absolute;top:-8px;right:-8px;background:var(--negative);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.95}.add-punch-btn{background:transparent;border:2px solid var(--border);border-radius:8px;width:100%;min-height:50px;position:relative;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.2rem;line-height:1;color:var(--text);opacity:.95;transition:opacity .2s ease,background-color .2s ease,color .2s ease}.add-punch-btn:hover{background:transparent;border-color:#22c55e;color:#22c55e;opacity:1}.add-punch-btn span{transform:none}.non-workday-label{flex:1;color:var(--muted);font-style:italic;min-height:50px;display:flex;align-items:center}.day-actions{display:flex;justify-content:flex-end;min-height:26px}.action-btn{background:transparent;border:none;padding:0 6px;cursor:pointer;font-size:1rem;line-height:1}.remove-day-btn{color:var(--muted);opacity:.65;transition:opacity .2s ease}.remove-day-btn:hover{opacity:1;color:#ef4444}.sketch-btn{border:2px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);padding:8px 12px;min-height:44px;cursor:pointer;font-family:var(--app-font-family);font-size:1.2rem;line-height:1}.sketch-btn:hover{transform:translateY(-1px)}.sketch-btn.danger{border-color:var(--negative);color:var(--negative)}.file-btn{position:relative;overflow:hidden}.file-btn input{position:absolute;inset:0;opacity:0;cursor:pointer}.pos{color:var(--positive)}.neg{color:var(--negative)}.metric-label{font-size:.7em;color:var(--muted)}.final-summary{border-top:2px solid var(--border);padding-top:18px;max-width:980px;margin:28px auto 48px}.final-summary-heading{text-transform:uppercase;font-size:1.1rem;margin-bottom:16px;text-align:center}.final-summary-toggle{width:fit-content;margin:0;background:transparent;color:var(--text);border:none;padding:0;cursor:pointer;font-family:var(--app-font-family);display:flex;align-items:center;gap:8px;opacity:.85;transition:opacity .2s ease}.final-summary-toggle-group{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:14px;margin-bottom:20px}.final-summary-toggle:hover{opacity:1}.final-summary-toggle.active{opacity:1;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:4px}.final-summary-toggle:focus-visible{outline:none;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:4px}.summary-caret{font-size:.7em;opacity:.55}.stats-summary{margin-top:12px;padding:12px;border:1px dashed var(--border);border-radius:10px;font-size:.85rem;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.stats-summary-title{text-transform:uppercase;font-size:.8em;letter-spacing:1px;text-align:center}.stats-summary-metrics{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:14px}.controls-block{position:fixed;left:50%;bottom:12px;transform:translate(-50%);width:min(calc(100% - 16px),760px);z-index:60;display:flex;flex-wrap:nowrap;justify-content:flex-start;gap:8px;align-items:center;padding:8px 10px;border:1px solid color-mix(in srgb,var(--border) 10%,transparent);border-radius:16px;background:linear-gradient(to bottom,color-mix(in srgb,var(--surface) 26%,transparent),color-mix(in srgb,var(--surface) 16%,transparent) 62%,color-mix(in srgb,var(--surface) 8%,transparent));-webkit-backdrop-filter:blur(12px) saturate(115%);backdrop-filter:blur(12px) saturate(115%);box-shadow:0 8px 20px #0000001a;overflow-x:auto;scrollbar-width:none}.controls-block::-webkit-scrollbar{display:none}.controls-block .control-add-btn{flex:0 0 auto;min-width:104px;min-height:42px;border-radius:999px;padding:6px 10px;display:inline-flex;align-items:center;justify-content:center;gap:0;font-size:.95rem;line-height:1;white-space:nowrap}.control-add-label{display:inline}.site-notice{position:fixed;right:12px;top:12px;z-index:1000;display:inline-flex;align-items:center;gap:10px;max-width:min(560px,calc(100vw - 24px));border:1px solid color-mix(in srgb,var(--border) 32%,transparent);border-radius:10px;background:color-mix(in srgb,var(--surface) 96%,transparent);color:var(--text);box-shadow:0 12px 28px #00000024;padding:10px 12px;font-size:.95rem;line-height:1.35;animation:site-notice-in .18s var(--ease-snappy) both}.site-notice.site-notice-success{border-color:color-mix(in srgb,var(--positive) 55%,transparent)}.site-notice.site-notice-error{border-color:color-mix(in srgb,var(--negative) 55%,transparent)}.site-notice.site-notice-info{border-color:color-mix(in srgb,var(--accent) 48%,transparent)}.site-notice-close{border:none;background:transparent;color:inherit;font-size:1.1rem;line-height:1;width:20px;height:20px;padding:0;cursor:pointer;opacity:.72;transition:opacity var(--dur-fast) var(--ease-snappy),transform var(--dur-fast) var(--ease-snappy)}.site-notice-close:hover{opacity:1;transform:scale(1.08)}@keyframes site-notice-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.day-type-select{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:4px;height:100%}@media(min-width:900px){.app{padding:16px 16px 150px}.header{flex-direction:row;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:14px}.header-main{min-width:280px;flex:1;max-width:560px}.workspace-field-wrap{width:min(420px,100%)}.header-actions{display:flex;flex-wrap:wrap;justify-content:flex-end}.header-actions>.workspace-field-inline{width:clamp(132px,var(--workspace-inline-width, 18ch),240px);flex:0 1 clamp(132px,var(--workspace-inline-width, 18ch),240px)}.header-actions>.sketch-btn,.header-actions>label.sketch-btn{width:50px!important;height:50px!important}.header-actions>.header-menu-wrap{width:50px;height:50px}.header-menu-toggle{width:50px;height:50px}.header-balance{grid-column:auto;width:120px}.month-group{margin-bottom:32px}.year-header{gap:10px;margin-bottom:12px;padding-bottom:10px}.year-title{font-size:1.46rem}.year-content{padding-left:14px}.month-header{align-items:center;margin-bottom:12px;gap:8px}.month-title{font-size:1.28rem;margin-bottom:0;letter-spacing:.02em}.month-sort-btn{height:30px;font-size:.85rem}.month-sort-controls{gap:8px}.month-view-controls{margin-left:auto}.days-wrapper{width:100%;max-width:1040px;min-width:min(1024px,calc(100vw - 32px))}.day-row{display:flex;gap:8px;align-items:flex-start;flex-wrap:wrap;margin-bottom:8px;padding:8px 10px;border:none;border-radius:10px;background:transparent}.missing-day-row{border:none;padding:0 10px;opacity:.3;align-items:center;min-height:0;margin-bottom:0}.missing-day-row:hover,.missing-day-row:focus-within{opacity:.6;background:color-mix(in srgb,var(--row-hover) 30%,transparent)}.missing-day-row.menu-open,.missing-day-row.menu-open:hover{opacity:1;z-index:100;position:relative}.day-stats-column{width:420px;flex-shrink:0}.stats-block{grid-template-columns:repeat(3,1fr) 1.4fr;gap:4px;width:420px}.date-block{width:160px;flex-shrink:0;min-height:50px}.desktop-widgets-rail{position:fixed;left:12px;top:132px;z-index:38;display:flex;flex-direction:column;gap:8px}.desktop-today-clock,.desktop-weather-widget{display:flex;flex-direction:column;justify-content:flex-start;gap:4px;min-height:72px;padding:6px 8px 4px;border:1px solid color-mix(in srgb,var(--border) 10%,transparent);border-radius:10px;background:color-mix(in srgb,var(--bg) 72%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:.86}.desktop-today-clock-time{font-size:1.5rem;font-weight:600;line-height:1;letter-spacing:.02em;color:color-mix(in srgb,var(--text) 88%,var(--muted))}.desktop-today-clock-periods{display:flex;flex-direction:column;gap:2px}.desktop-today-clock-row,.desktop-today-clock-total{display:flex;align-items:baseline;justify-content:space-between;gap:6px;font-size:.8rem;color:var(--muted)}.desktop-today-clock-total{margin-top:2px;padding-top:4px;border-top:1px dashed color-mix(in srgb,var(--border) 14%,transparent);font-size:.83rem}.desktop-today-clock-row strong,.desktop-today-clock-total strong{color:color-mix(in srgb,var(--text) 90%,var(--muted));font-weight:600}.desktop-today-clock-empty{font-size:.8rem;color:var(--muted);line-height:1.25;margin-top:2px}.desktop-weather-title{font-size:1rem;font-weight:600;letter-spacing:.02em;color:color-mix(in srgb,var(--text) 86%,var(--muted))}.desktop-weather-content{display:flex;flex-direction:column;gap:3px;overflow:visible}.desktop-weather-subtitle{font-size:.73rem;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.desktop-weather-subtitle-gap{margin-top:4px}.desktop-weather-hours,.desktop-weather-days{display:flex;flex-direction:column;gap:2px;overflow:visible}.desktop-weather-row{display:grid;grid-template-columns:1fr auto minmax(42px,auto);gap:6px;align-items:baseline;font-size:.8rem;color:var(--muted);overflow:visible}.desktop-weather-rain-inline{display:inline-flex;align-items:center;gap:4px;white-space:nowrap;justify-content:flex-end;overflow:visible}.desktop-weather-rain-inline>span:last-child{display:inline-block;min-width:3ch;text-align:right;font-variant-numeric:tabular-nums}.desktop-weather-wi{width:14px;height:14px;display:inline-block;flex-shrink:0;position:relative;opacity:.72}.wi-clear:before{content:"";position:absolute;inset:2px;border-radius:50%;background:var(--text)}.wi-clear:after{content:"";position:absolute;inset:0;background:linear-gradient(var(--text),var(--text)) center 0 / 1.4px 3px no-repeat,linear-gradient(var(--text),var(--text)) center bottom / 1.4px 3px no-repeat,linear-gradient(var(--text),var(--text)) 0 center / 3px 1.4px no-repeat,linear-gradient(var(--text),var(--text)) right center / 3px 1.4px no-repeat}.wi-partly:before{content:"";position:absolute;left:5px;top:0;width:8px;height:8px;border-radius:50%;border:1.4px solid var(--text);background:transparent;box-sizing:border-box}.wi-partly:after{content:"";position:absolute;left:0;bottom:1px;width:12px;height:6px;border-radius:6px 6px 1px 1px;background:radial-gradient(circle at 3px 4px,var(--text) 2.5px,transparent 2.7px),radial-gradient(circle at 7px 2px,var(--text) 3px,transparent 3.2px),linear-gradient(var(--text),var(--text));background-size:6px 6px,7px 7px,10px 3px;background-position:0 0,3px 0,1px 3px;background-repeat:no-repeat}.wi-cloudy:before{content:"";position:absolute;left:1px;top:2px;width:12px;height:7px;border-radius:6px 6px 1px 1px;background:radial-gradient(circle at 3px 5px,var(--text) 2.8px,transparent 3px),radial-gradient(circle at 7px 2px,var(--text) 3.2px,transparent 3.4px),radial-gradient(circle at 10px 4px,var(--text) 2.4px,transparent 2.6px),linear-gradient(var(--text),var(--text));background-size:6px 6px,7px 7px,5px 5px,11px 4px;background-position:0 0,3px 0,7px 1px,1px 3px;background-repeat:no-repeat}.wi-fog:before{content:"";position:absolute;left:1px;top:3px;width:12px;height:8px;background:linear-gradient(var(--text),var(--text)) 0 0 / 12px 1.2px,linear-gradient(var(--text),var(--text)) 1px 3px / 10px 1.2px,linear-gradient(var(--text),var(--text)) 0 6px / 12px 1.2px;background-repeat:no-repeat}.wi-rain:before{content:"";position:absolute;left:1px;top:1px;width:12px;height:6px;border-radius:999px;background:radial-gradient(circle at 3px 4px,var(--text) 2.5px,transparent 2.7px),radial-gradient(circle at 7px 2px,var(--text) 3px,transparent 3.2px),radial-gradient(circle at 10px 4px,var(--text) 2.2px,transparent 2.4px),linear-gradient(var(--text),var(--text));background-size:6px 6px,7px 7px,5px 5px,11px 3px;background-position:0 0,3px 0,7px 1px,1px 3px;background-repeat:no-repeat}.wi-rain:after{content:"";position:absolute;left:2px;bottom:0;width:10px;height:4px;background:linear-gradient(var(--text),var(--text)) 1px 0 / 1.2px 4px no-repeat,linear-gradient(var(--text),var(--text)) 4.5px 0 / 1.2px 4px no-repeat,linear-gradient(var(--text),var(--text)) 8px 0 / 1.2px 4px no-repeat}.wi-snow:before{content:"";position:absolute;left:1px;top:1px;width:12px;height:6px;border-radius:999px;background:radial-gradient(circle at 3px 4px,var(--text) 2.5px,transparent 2.7px),radial-gradient(circle at 7px 2px,var(--text) 3px,transparent 3.2px),radial-gradient(circle at 10px 4px,var(--text) 2.2px,transparent 2.4px),linear-gradient(var(--text),var(--text));background-size:6px 6px,7px 7px,5px 5px,11px 3px;background-position:0 0,3px 0,7px 1px,1px 3px;background-repeat:no-repeat}.wi-snow:after{content:"";position:absolute;left:2px;bottom:0;width:10px;height:4px;background:radial-gradient(var(--text) 1px,transparent 1.2px) 1.5px .5px / 3.5px 3.5px no-repeat,radial-gradient(var(--text) 1px,transparent 1.2px) 5px .5px / 3.5px 3.5px no-repeat,radial-gradient(var(--text) 1px,transparent 1.2px) 8.5px .5px / 3.5px 3.5px no-repeat}.wi-storm:before{content:"";position:absolute;left:1px;top:0;width:12px;height:6px;border-radius:999px;background:radial-gradient(circle at 3px 4px,var(--text) 2.5px,transparent 2.7px),radial-gradient(circle at 7px 2px,var(--text) 3px,transparent 3.2px),radial-gradient(circle at 10px 4px,var(--text) 2.2px,transparent 2.4px),linear-gradient(var(--text),var(--text));background-size:6px 6px,7px 7px,5px 5px,11px 3px;background-position:0 0,3px 0,7px 1px,1px 3px;background-repeat:no-repeat}.wi-storm:after{content:"";position:absolute;left:5px;bottom:0;width:5px;height:7px;clip-path:polygon(40% 0%,100% 0%,30% 50%,70% 50%,0% 100%,30% 45%,0% 45%);background:var(--text)}.desktop-weather-rain-tip{position:relative;cursor:help;outline:none}.desktop-weather-rain-tip:after{content:attr(data-tooltip);position:absolute;left:50%;bottom:calc(100% + 8px);transform:translate(-50%);min-width:180px;max-width:240px;padding:6px 8px;border-radius:8px;border:1px solid color-mix(in srgb,var(--border) 24%,transparent);background:color-mix(in srgb,var(--surface) 96%,transparent);color:var(--text);font-size:.72rem;line-height:1.25;text-align:left;white-space:normal;overflow-wrap:anywhere;word-break:normal;box-shadow:0 6px 16px #0000001f;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:12}.desktop-weather-rain-tip:hover:after,.desktop-weather-rain-tip:focus-visible:after{opacity:1}.desktop-weather-rain-inline>.desktop-weather-rain-tip:after{min-width:180px;max-width:min(320px,calc(100vw - 24px));white-space:normal;transform:translate(-50%)}.desktop-weather-empty{font-size:.8rem;color:var(--muted);line-height:1.25}.missing-day-date-slot{width:160px;flex-shrink:0;min-height:0;padding:0 8px}.weekday-pill{width:35px;min-height:50px;padding:0;border:none;border-radius:0;display:flex;align-items:center;justify-content:center;margin-right:4px}.punches-block{display:flex;align-items:center;gap:6px;flex-wrap:wrap;flex:1}.punch-input{width:62px}.delete-punch-btn{opacity:0;transition:opacity .2s;pointer-events:none}.punch-wrapper:hover .delete-punch-btn{opacity:1;pointer-events:auto}.add-punch-btn{border-radius:3px;width:22px;min-height:22px;height:22px;padding:0;transform:rotate(45deg);opacity:.35;pointer-events:auto}.add-punch-btn span{display:block;width:10px;height:10px;font-size:0;transform:rotate(-45deg);position:relative}.add-punch-btn span:before,.add-punch-btn span:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);background:currentColor;border-radius:999px}.add-punch-btn span:before{width:10px;height:1.6px}.add-punch-btn span:after{width:1.6px;height:10px}.day-row:hover .add-punch-btn,.day-row:focus-within .add-punch-btn{opacity:.9;pointer-events:auto}.day-actions{justify-content:flex-start;gap:4px}.missing-day-actions-spacer{width:35px;min-height:0}.action-btn{background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 8px;font-size:.9rem;opacity:.2;transition:opacity .2s,background .2s;height:50px;display:flex;align-items:center}.action-btn:hover{background:#eee;opacity:1}.dark-mode .action-btn:hover{background:#333}.remove-day-btn{opacity:0;pointer-events:none;height:50px;width:35px;display:flex;align-items:center;justify-content:center}.day-row:hover .remove-day-btn,.day-row:focus-within .remove-day-btn{opacity:.45;pointer-events:auto}.missing-day-tail{display:none}.controls-block{width:fit-content;max-width:calc(100% - 20px);flex-wrap:wrap;justify-content:center;gap:12px;overflow:visible}.controls-block .control-add-btn{min-width:0;min-height:44px;border-radius:10px;padding:8px 12px;font-size:1.12rem;gap:0}.app.view-mode-compact .day-row{margin-bottom:8px;padding:6px 8px;border:1px solid color-mix(in srgb,var(--border) 12%,transparent);border-radius:8px;background:color-mix(in srgb,var(--surface) 62%,transparent)}.app.view-mode-compact .day-row:hover,.app.view-mode-compact .day-row:focus-within{background:color-mix(in srgb,var(--row-hover) 55%,transparent)}.app.view-mode-compact .stats-block{grid-template-columns:repeat(4,minmax(0,1fr));gap:4px}.app.view-mode-compact .stats-block.no-goal{grid-template-columns:repeat(3,minmax(0,1fr))}.app.view-mode-compact .day-stats-column .stat-box{min-height:38px;border-width:1px;border-style:dashed;border-color:color-mix(in srgb,var(--border) 28%,transparent);border-radius:6px;background:transparent;padding:2px 6px}.app.view-mode-compact .day-stats-column .stat-box label{font-size:.62rem;opacity:.8}.app.view-mode-compact .day-stats-column .stat-box strong,.app.view-mode-compact .day-stats-column .goal-input{font-size:.94rem}.app.view-mode-compact .exit-suggestion-text{margin-top:2px;padding-left:0;font-size:.68rem;opacity:.72}.app.view-mode-compact .date-block{min-height:38px;border-width:1px;border-style:dashed;border-color:color-mix(in srgb,var(--border) 26%,transparent);border-radius:6px;background:transparent;padding:2px 6px}.app.view-mode-compact .date-input{font-size:.9rem}.app.view-mode-compact .weekday-pill{font-size:.62rem;opacity:.62;border:none}.app.view-mode-compact .punches-block{gap:4px}.app.view-mode-compact .punch-input{width:56px;min-height:38px;border-width:1px;border-radius:6px;font-size:.9rem;padding:2px 4px}.app.view-mode-compact .add-punch-btn{width:20px;min-height:20px;height:20px;opacity:.28}.app.view-mode-compact .add-punch-btn span{width:8px;height:8px}.app.view-mode-compact .add-punch-btn span:before{width:8px}.app.view-mode-compact .add-punch-btn span:after{height:8px}.app.view-mode-compact .day-actions{justify-content:center;align-items:center;min-height:38px}.app.view-mode-compact .remove-day-btn{opacity:.24;pointer-events:auto;height:28px;width:24px}.app.view-mode-compact .missing-day-row{border:none;border-radius:0;background:transparent;padding:0 8px;margin-bottom:0}.app.view-mode-compact .missing-day-date-slot{justify-content:flex-start;min-height:0}.app.view-mode-compact .missing-day-date-text{font-size:.68rem;opacity:.7}.app.view-mode-plain-list .month-content-list{--plain-list-cols: 36px 132px 46px minmax(320px, 1fr) minmax(300px, 1fr);border:1px solid color-mix(in srgb,var(--border) 24%,transparent);border-radius:10px;overflow:hidden;background:color-mix(in srgb,var(--surface) 90%,transparent)}.app.view-mode-plain-list .plain-list-head{display:grid;grid-template-columns:var(--plain-list-cols);align-items:center;min-height:34px;background:color-mix(in srgb,var(--row-hover) 34%,transparent);border-bottom:1px solid color-mix(in srgb,var(--border) 28%,transparent)}.app.view-mode-plain-list .plain-list-head>span{min-height:34px;display:flex;align-items:center;font-size:.67rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);padding:0 8px;border-right:1px solid color-mix(in srgb,var(--border) 18%,transparent)}.app.view-mode-plain-list .plain-list-head>span:last-child{border-right:none}.app.view-mode-plain-list .day-row{display:grid;grid-template-columns:var(--plain-list-cols);grid-template-areas:"actions date weekday stats punches";gap:0;align-items:stretch;margin-bottom:0;padding:0;border:none;border-bottom:1px solid color-mix(in srgb,var(--border) 16%,transparent);border-radius:0;background:transparent}.app.view-mode-plain-list .day-row:hover,.app.view-mode-plain-list .day-row:focus-within{background:color-mix(in srgb,var(--row-hover) 24%,transparent)}.app.view-mode-plain-list .day-actions{grid-area:actions;min-height:38px;justify-content:center;align-items:center;border-right:1px solid color-mix(in srgb,var(--border) 16%,transparent)}.app.view-mode-plain-list .remove-day-btn{opacity:.12;pointer-events:auto;height:24px;width:20px}.app.view-mode-plain-list .date-block{grid-area:date;width:100%;min-height:38px;border:none;border-radius:0;background:transparent;padding:0 8px;justify-content:flex-start;border-right:1px solid color-mix(in srgb,var(--border) 16%,transparent)}.app.view-mode-plain-list .date-input{font-size:.84rem;line-height:1}.app.view-mode-plain-list .weekday-pill{grid-area:weekday;min-height:38px;width:100%;margin-right:0;border:none;border-radius:0;opacity:.6;font-size:.64rem;border-right:1px solid color-mix(in srgb,var(--border) 16%,transparent)}.app.view-mode-plain-list .punches-block{grid-area:punches;display:flex;align-items:center;gap:5px;flex-wrap:wrap;min-height:38px;padding:4px 8px;border-right:1px solid color-mix(in srgb,var(--border) 16%,transparent)}.app.view-mode-plain-list .punch-input{width:56px;min-height:28px;border:1px solid color-mix(in srgb,var(--border) 26%,transparent);border-radius:4px;background:transparent;padding:1px 4px;font-size:.8rem}.app.view-mode-plain-list .punch-input::placeholder{font-size:.66rem}.app.view-mode-plain-list .add-punch-btn{width:14px;min-height:14px;height:14px;opacity:.16}.app.view-mode-plain-list .add-punch-btn span{width:6px;height:6px}.app.view-mode-plain-list .add-punch-btn span:before{width:6px}.app.view-mode-plain-list .add-punch-btn span:after{height:6px}.app.view-mode-plain-list .non-workday-label{grid-area:punches;min-height:38px;font-size:.82rem;opacity:.75;border-right:1px solid color-mix(in srgb,var(--border) 16%,transparent);padding:4px 8px;font-style:normal}.app.view-mode-plain-list .day-stats-column{grid-area:stats;width:100%;min-width:0;padding:4px 8px}.app.view-mode-plain-list .stats-block{width:100%;max-width:none;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.app.view-mode-plain-list .stats-block.no-goal{grid-template-columns:repeat(3,minmax(0,1fr))}.app.view-mode-plain-list .day-stats-column .stat-box{min-height:auto;border:none;background:transparent;border-radius:0;padding:0;text-align:left;display:flex;flex-direction:column;align-items:flex-start;gap:2px}.app.view-mode-plain-list .day-stats-column .stat-box label{font-size:.61rem;text-transform:uppercase;letter-spacing:.04em;opacity:.66}.app.view-mode-plain-list .day-stats-column .stat-box strong{font-size:.82rem}.app.view-mode-plain-list .day-stats-column .goal-input{width:100%;min-width:0;min-height:24px;border-width:1px;border-style:dashed;border-color:color-mix(in srgb,var(--border) 28%,transparent);border-radius:4px;background:transparent;padding:1px 4px;font-size:.78rem;text-align:left}.app.view-mode-plain-list .exit-suggestion-text{margin-top:2px;padding-left:0;font-size:.64rem;opacity:.68}.app.view-mode-plain-list .missing-day-row{display:grid;grid-template-columns:var(--plain-list-cols);grid-template-areas:"actions date weekday stats punches";gap:0;align-items:stretch;margin-bottom:0;padding:0;border:none;border-bottom:1px solid color-mix(in srgb,var(--border) 8%,transparent);border-radius:0;background:transparent;opacity:.35}.app.view-mode-plain-list .missing-day-row:hover,.app.view-mode-plain-list .missing-day-row:focus-within{opacity:.7;background:color-mix(in srgb,var(--row-hover) 16%,transparent)}.app.view-mode-plain-list .missing-day-row.menu-open,.app.view-mode-plain-list .missing-day-row.menu-open:hover{opacity:1;z-index:100;position:relative}.app.view-mode-plain-list .missing-day-actions-spacer{grid-area:actions;min-height:20px;border-right:1px solid color-mix(in srgb,var(--border) 10%,transparent)}.app.view-mode-plain-list .missing-day-date-slot{grid-area:date;width:100%;min-width:0;min-height:20px;padding:0 8px;gap:6px;border-right:1px solid color-mix(in srgb,var(--border) 10%,transparent);display:flex;align-items:center;justify-content:flex-start}.app.view-mode-plain-list .missing-day-weekday{grid-area:weekday;min-height:20px;display:block;height:auto;overflow:visible;border-right:1px solid color-mix(in srgb,var(--border) 10%,transparent)}.app.view-mode-plain-list .missing-day-tail{grid-area:punches;display:block;min-height:20px;border-right:1px solid color-mix(in srgb,var(--border) 10%,transparent)}.app.view-mode-plain-list .missing-day-stats{grid-area:stats;display:block;min-height:20px}.app.view-mode-plain-list .missing-day-date-text{font-size:.72rem;opacity:.7}.app.view-mode-plain-list .missing-day-inline-add-btn{width:16px;min-height:16px;height:16px;opacity:.18;pointer-events:auto;border-color:transparent;transition:opacity .2s ease,border-color .2s ease}.app.view-mode-plain-list .missing-day-inline-add-btn:hover{border-color:var(--border);opacity:.5}.app.view-mode-plain-list .missing-day-inline-add-btn span{width:7px;height:7px}.app.view-mode-plain-list .missing-day-inline-add-btn span:before{width:7px;height:1.3px}.app.view-mode-plain-list .missing-day-inline-add-btn span:after{width:1.3px;height:7px}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:999;padding:12px}.modal-content{background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:18px;box-shadow:4px 4px #0000001a;text-align:center;font-family:var(--app-font-family);font-size:1.1rem;min-width:min(300px,100%);width:min(100%,560px)}.settings-modal{max-height:calc(100vh - 24px);max-height:calc(100dvh - 24px);overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.settings-title{margin:0 0 10px}.settings-section{border:1px dashed color-mix(in srgb,var(--border) 24%,transparent);border-radius:10px;padding:12px;margin-bottom:12px;background:color-mix(in srgb,var(--surface) 88%,transparent)}.settings-section-title{margin:0 0 10px;font-size:1rem}.settings-block{margin-bottom:16px}.settings-block-last{margin-bottom:0}.settings-check{margin-bottom:8px;display:flex;align-items:center;gap:8px}.settings-check-spaced{margin-top:10px;margin-bottom:0}.settings-check-no-margin{margin-bottom:0}.settings-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.settings-field-label{display:block;margin-bottom:4px;font-size:.9rem}.settings-modal-actions{justify-content:flex-end;gap:8px}.release-notes-modal{width:min(100%,860px);max-height:min(86vh,920px);text-align:left;display:flex;flex-direction:column;gap:12px}.release-notes-header{display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap}.release-notes-title{margin:0}.release-notes-subtitle{font-size:.9rem;color:var(--muted)}.release-notes-list{display:flex;flex-direction:column;gap:10px;overflow:auto;padding-right:4px}.release-note-card{border:1px dashed color-mix(in srgb,var(--border) 45%,transparent);border-radius:10px;padding:10px 12px;background:color-mix(in srgb,var(--surface) 92%,transparent)}.release-note-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px;margin-bottom:2px}.release-note-top span{font-size:.88rem;color:var(--muted)}.release-note-summary{margin:0 0 8px}.release-note-section h4{margin:8px 0 4px;font-size:1rem}.release-note-section ul{margin:0;padding-left:18px}.release-note-section li{margin:2px 0}.modal-actions{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:18px;flex-wrap:wrap}.success-modal{min-width:320px;max-width:420px;border-width:3px;box-shadow:6px 6px #0000001f}.success-progress-track{margin-top:16px;width:100%;height:10px;border:2px solid var(--border);border-radius:999px;background:var(--surface);overflow:hidden}.success-progress-fill{width:100%;height:100%;background:repeating-linear-gradient(-45deg,var(--accent),var(--accent) 8px,color-mix(in srgb,var(--accent) 75%,white) 8px,color-mix(in srgb,var(--accent) 75%,white) 16px);border-radius:999px;transform-origin:left center;animation-name:auto-close-progress;animation-timing-function:linear;animation-fill-mode:forwards}.success-modal-actions{display:flex;justify-content:center;margin-top:16px}@keyframes auto-close-progress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}::view-transition-old(root),::view-transition-new(root){animation:none;mix-blend-mode:normal}::view-transition-old(root){z-index:1}::view-transition-new(root){z-index:2}.sketch-input{background:var(--surface);border:2px solid var(--border);border-radius:8px;padding:8px;color:var(--text);font-family:inherit;font-size:1rem}
