:root{--bg: #fafaf9;--card: #ffffff;--card-2: #f4f4f5;--text: #18181b;--text-2: #3f3f46;--muted: #a1a1aa;--border: #e4e4e7;--border-2: #f4f4f5;--accent: #18181b;--on-accent: #ffffff;--p1: #ef4444;--p2: #f59e0b;--p3: #3b82f6;--done: #10b981;--overlay: rgba(0,0,0,.35);--shadow: 0 1px 2px rgba(0,0,0,.04), 0 1px 3px rgba(0,0,0,.03);--shadow-md: 0 4px 6px rgba(0,0,0,.04), 0 10px 15px rgba(0,0,0,.04)}:root[data-theme=dark]{--bg: #18181b;--card: #232327;--card-2: #1d1d20;--text: #b8b8c0;--text-2: #8d8d97;--muted: #5e5e68;--border: #2e2e34;--border-2: #232327;--accent: #e8e8ed;--on-accent: #18181b;--p1: #f87171;--p2: #fbbf24;--p3: #60a5fa;--done: #34d399;--overlay: rgba(0,0,0,.6);--shadow: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.25);--shadow-md: 0 4px 6px rgba(0,0,0,.3), 0 10px 15px rgba(0,0,0,.25)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{min-height:100%}html,body{background:var(--bg);transition:background .2s}body{font-family:Manrope,-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI,Roboto,sans-serif;color:var(--text);line-height:1.4;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;font-size:15px}button,input,select,textarea{font-family:inherit;color:inherit}button{cursor:pointer;border:none;background:none}.app{max-width:780px;margin:0 auto;padding:max(18px,env(safe-area-inset-top)) 18px max(80px,env(safe-area-inset-bottom))}@media (min-width: 768px){.app{padding:26px 24px 80px}}.appbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;padding:10px 2px 12px;background:linear-gradient(var(--bg) 72%,transparent)}.logo{display:flex;align-items:center;gap:9px;font-weight:700;letter-spacing:-.02em;font-size:16px}.logo .mark{width:24px;height:24px;border-radius:8px;background:var(--accent);color:var(--on-accent);display:grid;place-items:center;font-size:13px}.logo .sub{color:var(--muted);font-weight:500}.spacer{flex:1}.icon-btn{width:36px;height:36px;border-radius:10px;color:var(--text-2);display:grid;place-items:center;transition:background .15s,color .15s;font-size:15px}.icon-btn:hover{background:var(--card-2);color:var(--text)}.tabs{display:flex;gap:2px;background:var(--card-2);border:1px solid var(--border);border-radius:10px;padding:3px;margin-left:6px}.tabs button{padding:6px 14px;border-radius:8px;font-size:13.5px;font-weight:600;color:var(--text-2)}.tabs button.on{background:var(--card);color:var(--text);box-shadow:var(--shadow)}.dash{margin-top:6px}.periods{display:flex;align-items:center;gap:6px;flex-wrap:nowrap;margin-bottom:18px}.periods .sep{color:var(--muted);margin:0 2px}.cal-catch{position:fixed;top:0;right:0;bottom:0;left:0;z-index:69}.cal-pop{position:absolute;top:calc(100% + 6px);left:0;z-index:70}@media (max-width: 640px){.periods{flex-wrap:wrap}}@keyframes tt-grow{0%{transform:scaleY(0)}to{transform:scaleY(1)}}@keyframes tt-scalex{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes tt-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes tt-fade{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.chip{padding:7px 13px;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:13px;font-weight:600;transition:all .15s}.chip:hover{border-color:var(--text-2);color:var(--text)}.chip.on{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}.dash-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.dash-card{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);animation:tt-up .4s ease both}.dash-cards .dash-card:nth-child(2){animation-delay:.06s}.dash-cards .dash-card:nth-child(3){animation-delay:.12s}.block-title{font-size:13px;font-weight:700;margin-bottom:14px}.block-title .muted{font-weight:500}.dc-label{color:var(--muted);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.dc-value{font-size:26px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.dc-value.sm{font-size:18px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-block{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:18px;box-shadow:var(--shadow);margin-top:14px;animation:tt-up .45s ease both}.chart-inner{position:relative}.barchart{width:100%;height:200px;display:block}.bar{transition:opacity .12s ease}.chart-tip{position:absolute;top:-6px;transform:translate(-50%);background:var(--text);color:var(--bg);padding:6px 10px;border-radius:9px;font-size:12px;white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md);display:flex;flex-direction:column;align-items:center;gap:1px;z-index:5;animation:tt-fade .12s ease}.chart-tip b{font-variant-numeric:tabular-nums;font-size:13px}.chart-tip span{opacity:.7;font-size:11px}.bar-labels{display:flex;justify-content:space-between;color:var(--muted);font-size:12px;margin-top:6px}.breakdown{display:flex;gap:22px;align-items:center}.donut-wrap{position:relative;flex:0 0 150px;width:150px;height:150px}.donut{width:150px;height:150px;animation:tt-fade .5s ease both}.donut-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.donut-center b{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.donut-center span{font-size:11px;color:var(--muted);font-weight:600}.bd-list{flex:1;min-width:0;display:flex;flex-direction:column;gap:11px}.bd-row{display:grid;grid-template-columns:12px 1fr auto auto;align-items:center;gap:9px;padding:4px 8px;margin:0 -8px;border-radius:9px;cursor:default;transition:background .12s ease}.bd-row.on{background:var(--card-2)}.bd-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13.5px;font-weight:500}.bd-time{font-variant-numeric:tabular-nums;font-size:13px;color:var(--text-2)}.bd-pct{font-variant-numeric:tabular-nums;font-size:12.5px;color:var(--muted);min-width:42px;text-align:right}.bd-bar{grid-column:2 / 5;height:5px;background:var(--card-2);border-radius:99px;overflow:hidden}.bd-bar>div{height:100%;border-radius:99px;transform-origin:left;animation:tt-scalex .6s cubic-bezier(.2,.85,.25,1) both}@media (max-width: 560px){.dash-cards{grid-template-columns:1fr}.breakdown{flex-direction:column;align-items:stretch}.donut-wrap{align-self:center}}.menu-wrap{position:relative}.menu-pop{position:absolute;right:0;top:calc(100% + 6px);z-index:60;min-width:224px;background:var(--card);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-md);padding:6px}.menu-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:11px 12px;border-radius:10px;color:var(--text);font-size:14px;font-weight:500;text-align:left}.menu-row:hover{background:var(--card-2)}.menu-row .chev{color:var(--muted);font-weight:400}.menu-row.danger{color:var(--p1)}.menu-sep{height:1px;background:var(--border-2);margin:6px}.menu-head{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:8px 12px 4px}.timer{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:8px 8px 8px 18px;box-shadow:var(--shadow);transition:box-shadow .2s,border-color .2s}.timer.running{border-color:var(--accent)}.timer .desc{flex:1;border:none;outline:none;background:transparent;font-size:16px;font-weight:500;padding:10px 0;min-width:0}.timer .desc::placeholder{color:var(--muted);font-weight:400}.proj-select{position:relative;display:flex;align-items:center;gap:7px;padding:9px 12px;border-radius:10px;color:var(--text-2);transition:background .15s;max-width:200px;white-space:nowrap;overflow:hidden}.proj-select:hover{background:var(--card-2)}.proj-select span{overflow:hidden;text-overflow:ellipsis}.proj-select select{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;cursor:pointer;width:100%;height:100%}.clock{font-variant-numeric:tabular-nums;font-feature-settings:"tnum";font-size:19px;font-weight:700;letter-spacing:-.01em;min-width:96px;text-align:right}.go{width:46px;height:46px;border-radius:50%;flex:0 0 auto;display:grid;place-items:center;color:var(--on-accent);background:var(--accent);transition:transform .08s,opacity .15s}.go:hover{opacity:.9}.go:active{transform:scale(.93)}.go.stop{background:var(--p1);color:#fff}.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:0 0 auto}.week-total{display:flex;justify-content:space-between;align-items:baseline;margin:30px 4px 12px;color:var(--muted);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em}.week-total b{color:var(--text);font-size:14px;font-variant-numeric:tabular-nums}.day{margin-bottom:16px}.day-head{display:flex;justify-content:space-between;align-items:baseline;padding:6px 6px 8px;color:var(--text-2)}.day-head .d{font-weight:700;font-size:14px}.day-head .t{font-variant-numeric:tabular-nums;font-weight:700;font-size:14px}.list{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}.entry{display:flex;align-items:center;gap:13px;padding:14px 16px;border-top:1px solid var(--border-2);cursor:pointer;transition:background .12s}.entry:first-child{border-top:none}.entry:hover{background:var(--card-2)}.entry .info{flex:1;min-width:0}.entry .title{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.entry .title.empty{color:var(--muted);font-weight:400}.entry .meta{display:flex;align-items:center;gap:7px;margin-top:3px;color:var(--text-2);font-size:12.5px}.entry .range{color:var(--muted);font-size:12.5px;font-variant-numeric:tabular-nums;white-space:nowrap}.entry .dur{font-variant-numeric:tabular-nums;font-weight:700;font-size:15px;min-width:72px;text-align:right}.entry .act{width:34px;height:34px;border-radius:10px;color:var(--muted);display:grid;place-items:center;opacity:0;transition:opacity .12s,background .12s,color .12s}.entry:hover .act{opacity:1}.entry .act:hover{background:var(--border-2);color:var(--text)}.entry .act.del:hover{color:var(--p1)}.btn{padding:10px 16px;border-radius:99px;background:transparent;border:1px solid var(--border);font-weight:600;color:var(--text-2);font-size:14px;transition:all .15s}.btn:hover{background:var(--card-2);color:var(--text)}.btn.primary{background:var(--accent);color:var(--on-accent);border-color:var(--accent)}.btn.primary:hover{opacity:.9}.btn:disabled{opacity:.4;cursor:not-allowed}.export{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:18px 4px 0;color:var(--text-2);font-size:13px}.datefield{position:relative}.datefield .df-btn{padding:8px 14px;border-radius:10px;background:var(--card-2);border:1px solid transparent;color:var(--text);font-size:14px;font-variant-numeric:tabular-nums;transition:all .15s}.datefield .df-btn:hover{border-color:var(--text-2)}.cal{margin-top:8px;background:var(--card);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:14px;width:100%;max-width:300px}.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cal-head .m{font-weight:700;font-size:14px}.cal-nav{width:30px;height:30px;border-radius:8px;color:var(--text-2);display:grid;place-items:center}.cal-nav:hover{background:var(--card-2);color:var(--text)}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.cal-dow{text-align:center;font-size:10.5px;font-weight:700;color:var(--muted);padding:4px 0;text-transform:uppercase}.cal-day{aspect-ratio:1;min-height:32px;border-radius:9px;display:grid;place-items:center;font-size:13px;color:var(--text);font-variant-numeric:tabular-nums;transition:background .1s}.cal-day:hover{background:var(--card-2)}.cal-day.other{color:var(--muted);opacity:.5}.cal-day.today{box-shadow:inset 0 0 0 1px var(--border)}.cal-day.sel{background:var(--accent);color:var(--on-accent);font-weight:700}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:150;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--card);border-left:1px solid var(--border);box-shadow:-8px 0 30px #00000029;z-index:160;display:flex;flex-direction:column;animation:slideIn .25s ease;overflow-y:auto;padding:max(18px,env(safe-area-inset-top)) 18px max(24px,env(safe-area-inset-bottom))}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.drawer-head h2{font-size:17px;font-weight:700}.drawer-sec{margin-top:24px}.drawer-sec>h3{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px}.proj-edit{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--card-2);border-radius:12px}.panel{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:16px;margin-top:12px;box-shadow:var(--shadow)}.panel h3{font-size:14px;font-weight:700;margin-bottom:12px}.row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.row input[type=text],.row input:not([type]){border:1px solid transparent;background:var(--card-2);border-radius:10px;padding:9px 12px;color:var(--text)}.row input:focus{outline:none;border-color:var(--accent);background:var(--card)}.chk{display:inline-flex;align-items:center;gap:6px;color:var(--text-2)}.proj-list{margin-top:12px;display:flex;flex-direction:column}.proj-item{display:flex;align-items:center;gap:9px;padding:10px 2px;border-top:1px solid var(--border-2);font-size:14px}.proj-item:first-child{border-top:none}.proj-item .rate{margin-left:auto;color:var(--text-2);font-size:12.5px;font-weight:600}.muted{color:var(--text-2)}.empty{text-align:center;color:var(--muted);padding:44px 0}.err{background:#ef444414;color:var(--p1);border:1px solid rgba(239,68,68,.25);border-radius:12px;padding:10px 14px;margin:10px 4px;font-size:13.5px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:200;display:flex;align-items:flex-end;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);padding:12px 12px calc(env(safe-area-inset-bottom) + 12px)}@media (min-width: 600px){.modal-overlay{align-items:center;padding:24px}}.modal-card{width:100%;max-width:520px;background:var(--card);border-radius:22px;padding:24px 22px 22px;animation:slideUp .25s ease;max-height:min(92vh,calc(100vh - 24px));overflow-y:auto;box-shadow:0 12px 40px #0000002e,0 4px 12px #00000014}@keyframes slideUp{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-card h3{font-size:18px;font-weight:700;margin-bottom:20px;letter-spacing:-.01em}.modal-label{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:8px;display:block}.modal-input,.modal-card textarea,.modal-card select{width:100%;background:var(--card-2);border:1px solid transparent;border-radius:12px;padding:13px 16px;color:var(--text);font-size:15px;outline:none;transition:all .15s;margin-bottom:16px}.modal-card textarea{resize:none;min-height:52px;max-height:200px;line-height:1.4}.modal-input:focus,.modal-card textarea:focus,.modal-card select:focus{background:var(--card);border-color:var(--accent)}.modal-input::placeholder,.modal-card textarea::placeholder{color:var(--muted)}.field-row{display:flex;gap:10px}.field-row>div{flex:1}.time-total{display:flex;align-items:center;gap:8px;margin-bottom:16px;color:var(--text-2);font-size:13px}.time-total b{color:var(--text);font-variant-numeric:tabular-nums;font-size:15px}.modal-actions{display:flex;gap:10px;margin-top:4px}.modal-cancel{flex:1;padding:13px;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:15px;font-weight:600;transition:all .15s}.modal-cancel:hover{background:var(--card-2);color:var(--text)}.modal-submit{flex:2;padding:13px;border-radius:99px;border:none;background:var(--accent);color:var(--on-accent);font-size:15px;font-weight:700;transition:opacity .15s}.modal-submit:hover{opacity:.9}.modal-delete{width:100%;margin-top:12px;padding:11px;border-radius:99px;border:1px solid var(--border);background:transparent;color:var(--p1);font-size:13px;font-weight:600;transition:all .15s}.modal-delete:hover{background:#ef444414;border-color:var(--p1)}.gate{min-height:100vh;display:grid;place-items:center;padding:20px}.gate .card{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:32px 28px;width:min(380px,92vw);box-shadow:var(--shadow-md);text-align:center}.gate .logo{justify-content:center;margin-bottom:6px}.gate p{color:var(--text-2);font-size:13.5px;margin:6px 0 20px}.gate input{width:100%;border:1px solid transparent;background:var(--card-2);border-radius:12px;padding:13px 16px;margin-bottom:12px;text-align:center}.gate input:focus{outline:none;border-color:var(--accent);background:var(--card)}.gate .btn{width:100%}@media (hover: none){.entry .act{opacity:1}}@media (max-width: 560px){.timer{flex-wrap:wrap;padding:10px;gap:8px;border-radius:16px}.timer .desc{flex:1 1 100%;order:1;padding:6px 4px}.proj-select{order:2;flex:1 1 auto;max-width:none}.clock{order:3;flex:0 0 auto}.timer .icon-btn,.timer .go{order:4}.entry{gap:10px;padding:13px 14px}.entry .range{display:none}.entry .dur{min-width:62px;font-size:14px}.week-total{margin-top:22px}}
