@import"https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@600;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@600;700&family=Parisienne&display=swap";:root{color-scheme:only light}.auth-shell{min-height:100vh;display:grid;grid-template-columns:minmax(320px,420px) 1fr;background:radial-gradient(circle at top left,#f5f7ff,#f7fbf8 55%,#fff)}.auth-card{padding:56px 48px;display:flex;flex-direction:column;gap:28px;background:#fff;box-shadow:0 18px 40px #0f172a14}.auth-card header h1{margin:6px 0 8px;font-size:2.1rem;letter-spacing:-.04em}.eyebrow{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#7f8a9b}.subtitle{color:#637083;line-height:1.5}.mode-toggle{display:flex;gap:8px;background:#f3f5f9;padding:6px;border-radius:999px}.mode-toggle button{flex:1;border:none;background:transparent;padding:10px 0;border-radius:999px;font-weight:600;color:#6a7688;cursor:pointer}.mode-toggle button.active{background:#fff;color:#222b38;box-shadow:0 8px 18px #0f172a1f}.auth-form{display:flex;flex-direction:column;gap:16px}.auth-form label{display:flex;flex-direction:column;gap:8px;font-weight:600;color:#334155}.auth-form input{border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px;font-size:.95rem;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.auth-form input:focus{border-color:#8b5cf6;box-shadow:0 0 0 4px #8b5cf62e}.status{padding:10px 12px;border-radius:10px;font-size:.9rem}.goals-simple .status{max-width:360px;margin:12px auto 0;text-align:center;min-height:22px}.status-row{min-height:28px}.status.error{background:#ffe8e8;color:#b33838}.status.success{background:#e4f7ef;color:#1d7a56}button.primary{border:none;border-radius:10px;padding:10px 16px;font-weight:600;background:linear-gradient(135deg,#c4b5fd,#a5b4fc);color:#fff;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,filter .2s ease}button.primary:hover{transform:translateY(-1px);box-shadow:0 10px 20px #a5b4fc80;filter:brightness(1.03)}button.primary:active{transform:translateY(0);box-shadow:0 6px 14px #a5b4fc73}button.primary.compact{padding:8px 14px;border-radius:9px}.auth-side{padding:72px 64px;display:flex;align-items:center;background:linear-gradient(120deg,#e0f3ffb3,#f4f7eccc)}.auth-side h2{font-size:2rem;margin-bottom:16px}.auth-side p{color:#546070;line-height:1.6;max-width:360px}.pill-row{display:flex;gap:10px;margin-top:24px;flex-wrap:wrap}.pill-row span{padding:6px 14px;border-radius:999px;background:#fffc;border:1px solid rgba(148,163,184,.4);font-size:.85rem;color:#475569}.app-shell{min-height:100vh;background:#f5f7fb;display:flex;flex-direction:column}.top-nav{display:flex;align-items:center;justify-content:space-between;padding:12px 28px;background:#e9f1f6;border-bottom:1px solid rgba(21,85,154,.18);position:sticky;top:0;z-index:10}.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:#15559a}.logo-dot{width:12px;height:12px;border-radius:999px;background:#15559a}.nav-buttons{display:flex;gap:12px}.nav-buttons button{border:none;background:transparent;padding:6px 10px;border-radius:999px;font-weight:600;color:#3f6da6;cursor:pointer}.nav-buttons button.active{background:#15559a;color:#e9f1f6}button.ghost{border:1px solid rgba(21,85,154,.35);background:#e9f1f6;padding:8px 14px;border-radius:10px;color:#15559a;cursor:pointer}.content{padding:48px 40px;flex:1}.page-transition{transition:none}.placeholder{background:#fff;border-radius:16px;padding:40px;box-shadow:0 18px 40px #0f172a14}.placeholder h2{margin:0 0 10px;font-size:1.8rem}.placeholder p{color:#64748b}.goals-simple{display:flex;flex-direction:column;gap:16px}.simple-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.simple-actions{display:flex;gap:10px}.goals-title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:.04em;color:#15559a;font-family:Playfair Display,Georgia,serif}.goal1-label{font-weight:700;color:#1f2937;font-size:1.2rem}.goal1-scope{--goal1-ink: #3b3a36;--goal1-paper: #e9e2d7;--goal1-slate: #c8d4db;--goal1-sage: #b6bfae;--goal1-terracotta: #c09a88;--goal1-dust: #bdb4a9}.goal1-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,220px));gap:16px;align-items:start;justify-content:center}.goal1-card{border:2px solid #7aa9b8;border-radius:28px;padding:14px;background:#e7f3f6;text-align:left;box-shadow:none;display:flex;flex-direction:column;gap:10px;transition:transform .15s ease;aspect-ratio:4 / 3;width:100%;position:relative;font-family:Georgia,Times New Roman,serif}.goal1-card-main{background:transparent;border:none;padding:0;text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:12px;min-height:100%}.goal1-input input{border:2px dashed #15559a;min-height:48px;padding:12px 14px;background:#fff}.goal1-button{background:#15559a;color:#e9f1f6;border:1px solid #15559a;box-shadow:none}.goals-create{background:#15559a;color:#e9f1f6;border:1px solid #15559a;box-shadow:0 8px 18px #15559a2e}.goals-create:hover{filter:brightness(1.03);box-shadow:0 10px 20px #15559a33}.goal1-button:hover{background:#15559a;color:#e9f1f6;box-shadow:none;filter:none}.goal1-card>*{position:relative;z-index:1}.goal1-card:hover{transform:translateY(-2px)}.goal1-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.goal1-badge{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--goal1-ink);background:transparent;padding:4px 8px;border-radius:999px;border:1.5px dashed #7aa9b8}.goal1-name{font-weight:600;color:var(--goal1-ink);font-size:1rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.goal1-ddl{font-size:.76rem;color:#2b6774;position:absolute;right:12px;bottom:10px}.goal1-card-color{width:26px;height:26px;border:none;background:transparent;padding:0;cursor:pointer}.goal1-card-color::-webkit-color-swatch-wrapper{padding:0}.goal1-card-color::-webkit-color-swatch{border:2px solid rgba(43,103,116,.4);border-radius:999px}.goal1-title{display:flex;flex-direction:column;align-items:flex-start;gap:6px;min-width:0}.goal1-card-delete{position:absolute;top:2px;right:2px;border:1px solid rgba(0,0,0,.12);background:#fff;color:#7a1f1f;padding:0;border-radius:999px;font-size:1rem;line-height:1;width:24px;height:24px;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .15s ease}.goal1-card:hover .goal1-card-delete{opacity:1;pointer-events:auto}.goal1-detail{display:flex;flex-direction:column;gap:16px;height:calc(100vh - 180px);min-height:520px}.goal1-detail-header{display:flex;align-items:center;flex-wrap:nowrap;gap:10px;flex:0 0 auto}.goal1-detail-header>*{align-self:center}.goal1-detail-header input,.goal1-detail-header select,.goal1-detail-header button{height:40px}.goal1-node-card{background:#fff;border:2px solid #e1e6ef;border-radius:18px;min-width:240px;max-width:280px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:none;position:relative;z-index:1;text-align:left;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.goal1-node-card.selected{border-color:#15559a;box-shadow:0 0 0 3px #15559a2e}.goal1-node-card.completed{background:#a0d8bb59;border-color:#9fcfb9;color:#506b5d}.goal1-tree{display:flex;justify-content:flex-start;padding:60px 18px 24px;overflow:auto;background:#f4f6fb;border-radius:18px;border:1px solid #e4e8f0;align-items:flex-start;position:relative;flex:1;min-height:0}.goal1-tree::-webkit-scrollbar{width:18px;height:18px}.goal1-tree::-webkit-scrollbar-track{background:linear-gradient(180deg,#e9ecf2e6,#f1f4fae6);border-radius:12px}.goal1-tree::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#9bbad6,#7aa9b8);border-radius:16px;border:3px solid rgba(244,246,251,.8);box-shadow:inset 0 0 0 1px #fff9}.goal1-tree::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#7ea2c4,#5d8fa5)}.goal1-tree{scrollbar-width:auto;scrollbar-color:#7aa9b8 rgba(233,236,242,.7)}.goal1-tree.logic-mode{background:#f1f6f2;align-items:flex-start;position:relative;padding-top:60px;padding-bottom:120px;scroll-padding-top:60px;scroll-padding-bottom:120px}.goal1-layout-toggle{position:sticky;top:2px;left:2px;align-self:flex-start;gap:8px;padding:8px 12px;width:auto;height:auto;min-height:40px;border-radius:12px;border-color:#c3d0e0;background:#fff;color:#2f4d75;box-shadow:0 14px 28px #15559a14;z-index:8;pointer-events:auto;flex-shrink:0}.goal1-tree.logic-mode .goal1-layout-toggle{background:#fff;border-color:#c3d0e0;color:#2f4d75;margin-top:-88px}.goal1-layout-toggle span{font-size:.88rem;font-weight:600}.goal1-branch{display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;padding:0 10px 16px;min-width:max-content}.goal1-branch.logic-mode{flex-direction:row;align-items:center;gap:18px;padding:8px 16px 8px 0}.goal1-node-title{font-weight:600;color:#2b3138;line-height:1.35;font-size:.92rem;font-family:Playfair Display,Georgia,serif}.goal1-node-meta{display:flex;flex-direction:column;gap:6px;font-size:.76rem;color:#6b7280}.goal1-node-row{display:flex;align-items:baseline;gap:6px}.goal1-node-label{letter-spacing:.08em;text-transform:uppercase;color:#7a8aa3;font-size:.68rem}.goal1-node-value{font-variant-numeric:tabular-nums;color:#3f4a5a;font-weight:500}.goal1-node-status{width:42px;height:6px;border-radius:999px;background:#4f9d7680}.goal1-node-card.completed .goal1-node-title,.goal1-node-card.completed .goal1-node-value,.goal1-node-card.completed .goal1-node-status{color:#6b7280}.goal1-add{background:#eef2fb;color:#3b4a6b}.goal1-add-header{margin-left:8px}.goal1-icon-button{border:1px solid #cbd5e1;background:#fff;color:#3b4a6b;padding:0;border-radius:12px;cursor:pointer;font-weight:600;width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;transition:background .15s ease,border-color .15s ease,color .15s ease}.goal1-icon-button svg{width:18px;height:18px}.goal1-back{border-color:#15559a;background:#e9f1f6;color:#15559a}.goal1-add{border-color:#a7bfe6;background:#e9f1fb;color:#2f5c9a}.goal1-save{border-color:#7fb99b;background:#e6f3ec;color:#2f7a56}.goal1-delete{border-color:#e4b2b2;background:#feecec;color:#b91c1c}.goal1-text-input{border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;min-width:220px;background:#fff}.goal1-inline-field{display:flex;align-items:center;gap:6px;font-size:.72rem;color:#6b7280}.goal1-inline-label{letter-spacing:.06em;text-transform:uppercase}.goal1-inline-input{border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;min-width:170px;background:#fff}.goal1-inline-select{border:1px solid #cbd5e1;border-radius:10px;padding:8px 10px;background:#fff}.goal1-children{display:flex;gap:32px;align-items:flex-start;position:relative;padding-top:42px;z-index:1;min-width:max-content}.goal1-children.logic-mode{flex-direction:column;gap:18px;padding-top:0;padding-left:48px;justify-content:center}.goal1-child-wrap{position:relative}.goal1-connectors{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:3;overflow:visible}.goal1-connectors.logic-mode{left:0;top:0;width:100%;height:100%}.goal1-connector-path{fill:none;stroke:#c2c9d6;stroke-width:2;stroke-linecap:round}.goal1-connector-dot{fill:#fff;stroke:#c2c9d6;stroke-width:2}.simple-input{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:center;margin-bottom:12px}.simple-input input,.drawer-form input,.drawer-form select{border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px;min-width:320px}.simple-layout{display:grid;grid-template-columns:1fr 2fr;gap:20px;align-items:start}.simple-list,.simple-editor{background:#fff;border-radius:12px;padding:16px;box-shadow:0 8px 20px #0f172a0f;min-height:420px}.timer-shell{display:flex;flex-direction:column;gap:16px}.timer-input{justify-content:center}.idle-timer{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:center;padding:10px 12px;border:1px dashed #cbd5f5;border-radius:10px;background:#f8fafc;width:min(520px,100%);margin:0 auto 6px}.idle-input{border:1px solid #d7ddeb;border-radius:10px;padding:10px 12px;background:#fff}.idle-clock{font-variant-numeric:tabular-nums;color:#475569;padding:0 8px;min-width:110px;text-align:center}.idle-submit{min-width:64px;border-radius:10px}.idle-submit.success{background:#22c55e;border-color:#16a34a;color:#fff;animation:note-pulse .5s ease}.timer-layout{display:grid;grid-template-columns:1.7fr 1fr;gap:20px;align-items:start;margin-top:20px}.timer-panel{background:transparent;border-radius:12px;padding:0;box-shadow:none;min-height:420px}.timer-card{border:1px solid #e2e8f0;border-radius:12px;padding:14px;background:#fff;box-shadow:0 8px 20px #0f172a0f;display:flex;flex-direction:column;gap:12px}.timer-list .simple-editor-title{margin-top:0}.timer-active{display:flex;flex-direction:column;gap:10px;padding:2px 4px 6px;text-align:center;align-items:center}.timer-empty{border:1px dashed #e2e8f0;border-radius:10px;padding:12px 14px;min-height:96px;display:flex;align-items:center;justify-content:center;background:#f8fafc}.timer-task{font-weight:600;color:#6e27a066}.timer-row{display:flex;align-items:center;gap:12px;justify-content:center}.timer-clock{font-size:1.9rem;font-weight:700;letter-spacing:.08em;color:#6e27a0a6}.timer-stop{width:36px;height:36px;min-width:36px;min-height:36px;flex:0 0 36px;border-radius:8px;border:1px solid #cbd5f5;background:transparent;box-shadow:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.timer-stop:hover{background:#eef2ff}.stop-icon{width:14px;height:14px;border-radius:2px;background:#6d28d9}.timer-history{margin-top:10px;display:flex;flex-direction:column;gap:10px}.timer-note{margin-top:14px;padding-top:8px}.timer-note-divider{border-top:1px dashed #cbd5f5;margin:4px 0 0}.timer-note-form{display:grid;grid-template-columns:1fr 52px;gap:10px;align-items:stretch;width:100%;margin-top:8px}.timer-note-form input{flex:1;border:1px solid #d7ddeb;border-radius:12px;padding:12px;background:#fff;width:100%}.note-submit-button{width:52px;border-radius:12px;border:1px solid #d7ddeb;background:#f8fafc;color:#475569;font-size:1.15rem;transition:background .2s ease,color .2s ease,border-color .2s ease,transform .2s ease}.note-submit-button:not(:disabled):hover{background:#eef2ff;color:#4c1d95}.note-submit-button.success{background:#22c55e;border-color:#16a34a;color:#fff;animation:note-pulse .5s ease}@keyframes note-pulse{0%{transform:scale(1)}50%{transform:scale(1.07)}to{transform:scale(1)}}.note-status{margin-top:6px;font-size:.85rem;color:#64748b;text-align:right}.timer-note-btn{width:48px;border-radius:12px;border:1px solid #d7ddeb;background:#f8fafc;color:#6d28d9;font-size:1.2rem;cursor:pointer;transition:background .2s ease,color .2s ease}.timer-note-btn:disabled{opacity:.4;cursor:not-allowed}.timer-note-btn:not(:disabled):hover{background:#eef2ff;color:#4c1d95}.history-list{display:flex;flex-direction:column;gap:0;border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;max-height:450px;overflow-y:auto;background:#fff}.history-header{font-size:.8rem;color:#94a3b8;text-transform:uppercase;letter-spacing:.12em;padding:2px 0 8px}.history-date-row{width:100%;text-align:center;border:none;background:transparent;font-size:.8rem;color:#94a3b8;padding:6px 0 4px;border-bottom:1px solid #e2e8f0;margin:6px 0 4px;cursor:pointer}.history-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px dashed #eef2f7}.history-time{width:120px;font-size:.85rem;color:#334155;font-variant-numeric:tabular-nums;text-align:left;background:transparent;border:none;padding:0;cursor:pointer}.history-title{font-size:.9rem;color:#1f2937;flex:1}.history-duration{font-size:.8rem;color:#94a3b8;white-space:nowrap;margin-left:auto}.history-edit{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}.history-edit input{border:1px solid #e2e8f0;border-radius:8px;padding:6px 8px;font-size:.85rem}.history-delete{border:none;background:transparent;color:#cbd5e1;font-size:1rem;cursor:pointer;padding:0 2px}.history-delete:hover{color:#94a3b8}.history-group:last-child .history-row{border-bottom:none}.simple-node{display:flex;flex-direction:column;gap:8px;position:relative}.simple-list>.simple-node{margin-bottom:14px}.simple-row{display:flex;align-items:center;gap:10px}.simple-item{flex:1;text-align:left;border:1px solid #e2e8f0;background:#f8fafc;padding:8px 10px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px}.simple-item.goal{background:#f3e8ff;border-color:#8b5cf659}.simple-item.task{background:#f8fafc}.simple-item.active{border-color:#0f172a;background:#fff}.simple-item.running{position:relative;border-color:#c4b5fd;box-shadow:0 0 0 3px #c4b5fd59;animation:pulse-ring 1.6s ease-in-out infinite}@keyframes pulse-ring{0%{box-shadow:0 0 0 2px #c4b5fd66}50%{box-shadow:0 0 0 6px #c4b5fd26}to{box-shadow:0 0 0 2px #c4b5fd66}}.goal-prefix{font-family:Parisienne,Playfair Display,Georgia,serif;font-weight:400;color:#7c3aed;letter-spacing:.02em}.goal-number{font-family:Playfair Display,Georgia,serif;font-weight:700;font-size:1.05em;letter-spacing:.04em}.node-content{flex:1;text-align:left}.node-ddl{font-size:.75rem;color:#94a3b8;white-space:nowrap}.simple-children{display:flex;flex-direction:column;gap:10px;margin-left:16px;padding-left:14px;border-left:1px solid rgba(139,92,246,.22)}.simple-children .simple-item:before{content:"";width:12px;height:2px;border-radius:999px;background:linear-gradient(90deg,#8b5cf673,#8b5cf600);display:inline-block;margin-right:6px}.simple-children .simple-item:after{content:none}.simple-editor-title{font-size:.85rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8;margin-bottom:12px}.simple-editor .drawer-form{gap:18px}.simple-editor .drawer-form label{font-weight:600;color:#1f2937;display:flex;align-items:center;justify-content:space-between;gap:12px}.simple-editor .drawer-form label input,.simple-editor .drawer-form label select{width:260px;flex:0 0 260px}.simple-editor .drawer-form input,.simple-editor .drawer-form select{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:10px 12px}.simple-editor .drawer-form input:focus,.simple-editor .drawer-form select:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 4px #8b5cf62e}.parent-hint{font-size:.85rem;color:#64748b;background:#f8fafc;padding:8px 10px;border-radius:10px}.simple-editor .drawer-form button.primary{align-self:flex-start;padding:10px 18px}.editor-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}.ghost.danger{border-color:#dc26264d;color:#b91c1c}.ghost.danger:hover{border-color:#dc262680}.orphan-section{margin-top:18px;padding-top:12px;border-top:1px dashed #e2e8f0}.orphan-list{display:flex;flex-direction:column;gap:10px;margin-top:10px}.daily-shell{display:flex;flex-direction:column;gap:18px}.daily-header{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:16px 18px;border-radius:14px;border:1px solid #e2e8f0;box-shadow:0 12px 28px #0f172a0f}.daily-nav{display:inline-flex;gap:10px}.daily-nav button{padding:6px 10px;border-radius:10px;min-width:44px}.daily-date{margin-top:6px;font-size:1.3rem;font-weight:700;color:#1f2937;letter-spacing:-.01em}.daily-clock{display:inline-flex;align-items:center;gap:6px;padding:4px 0;color:#1f2937;font-variant-numeric:tabular-nums}.clock-value{font-weight:700;font-size:1.05rem}.daily-layout{display:grid;grid-template-columns:minmax(300px,460px) 1fr;gap:18px;align-items:start}.timeline-panel{background:#fff;border-radius:14px;padding:16px;border:1px solid #e2e8f0;box-shadow:0 12px 28px #0f172a0f}.timeline-list{display:flex;flex-direction:column;gap:12px}.timeline-row{display:grid;grid-template-columns:120px 1fr;gap:12px;align-items:stretch}.timeline-left{display:flex;gap:10px;align-items:flex-start}.timeline-time{width:72px;text-align:right;font-variant-numeric:tabular-nums;color:#475569;padding-top:4px}.timeline-axis{position:relative;width:12px;min-height:100%;display:flex;justify-content:center}.timeline-axis:before{content:"";position:absolute;top:0;bottom:0;width:2px;border-radius:999px;background:#e2e8f0}.timeline-dot{width:12px;height:12px;border-radius:999px;background:#8b5cf6;border:3px solid #ede9fe;position:relative;z-index:1;box-shadow:0 0 0 4px #8b5cf61f}.timeline-dot.muted{background:#94a3b8;border-color:#e2e8f0;box-shadow:0 0 0 4px #94a3b82e}.timeline-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;box-shadow:0 6px 12px #81a4f000;position:relative}.timeline-card.orphan{background:#f1f5f9;border-color:#e2e8f0}.timeline-delete{position:absolute;top:-6px;right:-6px;width:26px;height:26px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#c53030;font-size:16px;line-height:1;display:inline-flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s ease,transform .15s ease;cursor:pointer;padding:0}.timeline-card:hover .timeline-delete{opacity:1}.timeline-delete:hover{transform:scale(1.05);background:#fff5f5;border-color:#fecdd3}.timeline-top{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:8px}.timeline-range{font-size:.88rem;color:#475569;font-variant-numeric:tabular-nums}.timeline-duration{font-size:.85rem;font-weight:700;color:#4c1d95;background:#ede9fe;padding:4px 8px;border-radius:999px;white-space:nowrap}.timeline-duration.muted{background:#e2e8f0;color:#475569}.weekly-shell{display:flex;flex-direction:column;gap:16px;margin-top:-8px}.week-header{display:flex;align-items:center;justify-content:space-between;background:#fff;padding:10px 12px;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 8px 18px #0f172a0d}.week-range{font-weight:700;color:#1f2937}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:0;align-items:start;border:1px solid #e2e8f0;background:#fff}.week-column{padding:10px;display:flex;flex-direction:column;gap:8px;border-left:1px solid #e2e8f0}.week-day-label{display:flex;align-items:baseline;justify-content:space-between;color:#475569}.week-day-name{font-weight:700;text-transform:uppercase;font-size:.9rem}.week-day-num{font-weight:700;color:#7c3aed}.day-track{position:relative;height:720px;box-sizing:border-box;background:repeating-linear-gradient(to bottom,#f8fafc 0,#f8fafc 30px,#f1f5f9 30px,#f1f5f9 60px);overflow:hidden}.day-hour-row{position:absolute;left:0;right:0;height:calc(100% / 24);display:flex;align-items:center;z-index:0}.day-hour-label{position:relative;left:4px;font-size:.78rem;color:#94a3b8;font-variant-numeric:tabular-nums}.day-block{position:absolute;left:6px;right:6px;background:#7c3aed1a;border:1px solid rgba(124,58,237,.3);border-radius:10px;padding:6px 8px;color:#1f2937;box-shadow:0 4px 10px #0f172a14;display:flex;flex-direction:column;gap:4px;z-index:1}.week-axis .week-day-label{justify-content:center}.day-block.orphan{background:#94a3b81f;border:1px solid rgba(148,163,184,.4)}.day-block-time{font-size:.8rem;color:#475569;font-variant-numeric:tabular-nums}.day-block-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-block-title.small{font-size:.85rem}.timeline-title{display:grid;grid-template-columns:1fr auto;align-items:center;gap:10px;font-weight:600;color:#1f2937;line-height:1.45}.timeline-note-actions{display:inline-flex;align-items:center;gap:6px}.timeline-title-text.muted{color:#68768b97}.note-sticker{width:30px;height:30px;border-radius:8px;border:1px dashed #f5d565;background:#fff9e6;padding:4px;display:inline-flex;align-items:center;justify-content:center;cursor:pointer}.note-sticker img{width:18px;height:18px;display:block}.note-add{width:28px;height:28px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#475569;cursor:pointer}.timeline-note-panel{position:absolute;top:100%;right:0;margin-top:8px;padding:12px;border:1px solid #e2e8f0;border-radius:12px;background:#fff;box-shadow:0 12px 28px #0f172a1f;min-width:240px;z-index:3}.note-list{display:flex;flex-direction:column;gap:10px}.note-item{display:flex;flex-direction:column;gap:4px}.note-meta{font-size:.78rem;color:#94a3b8;font-variant-numeric:tabular-nums}.note-text{color:#1f2937;line-height:1.5;position:relative;padding-right:20px}.note-divider{border-top:1px dashed #e2e8f0;margin-top:6px}.note-delete{position:absolute;right:0;top:2px;border:none;background:transparent;color:#cbd5e1;cursor:pointer;font-size:.9rem;padding:0}.note-item:hover .note-delete{color:#ef4444}.note-form{display:flex;gap:8px;align-items:center;margin-top:10px}.note-form input{flex:1;border:1px solid #e2e8f0;border-radius:8px;padding:8px 10px}.daily-summary{display:grid;grid-template-columns:repeat(2,minmax(280px,380px));gap:12px;align-items:start;justify-content:start}.summary-card{background:linear-gradient(135deg,#fff,#f8fafc 60%,#eef2ff);border-radius:16px;border:1px solid #e2e8f0;padding:18px;box-shadow:0 12px 28px #0f172a0f;display:grid;grid-template-columns:1fr;gap:14px;max-width:420px}.plan-card{background:linear-gradient(140deg,#fff,#f8fafc 55%,#fef3c7)}.plan-list{display:flex;flex-direction:column;gap:10px}.plan-row{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;padding:10px 12px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 6px 14px #0f172a0f}.plan-row.orphan{background:#f8fafc}.plan-index{font-weight:700;color:#f59e0b;font-variant-numeric:tabular-nums}.plan-main{display:flex;flex-direction:column;gap:6px;min-width:0}.plan-title{font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-meta{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:#64748b;font-variant-numeric:tabular-nums}.plan-time{padding:2px 8px;border-radius:999px;background:#fef3c7;color:#92400e;font-weight:600}.plan-dot{width:8px;height:8px;border-radius:999px;background:#8b5cf6}.summary-label{font-size:.85rem;font-weight:700;color:#94a3b8;letter-spacing:.08em;text-transform:uppercase}.summary-value{display:flex;align-items:baseline;justify-content:center;gap:12px;padding:12px;border-radius:12px;background:#fff;border:1px dashed #cbd5f5;font-variant-numeric:tabular-nums;font-size:1.35rem;font-weight:700;color:#0f172a}.summary-total-prefix{font-size:.9rem;font-weight:600;color:#94a3b8}.summary-sub{color:#64748b;font-size:.92rem}.project-chart{display:flex;flex-direction:column;gap:10px}.project-row{display:flex;flex-direction:column;gap:6px}.project-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.project-name{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-goal-tag{display:inline-flex;align-items:center;height:20px;padding:0 8px;border-radius:999px;background:transparent;border:1px dashed #c084fc;color:#6b21a8;font-size:.75rem;font-weight:700}.project-goal-number{font-weight:700;color:#7c3aed;margin-left:4px}.project-name-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.project-meta{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;color:#475569;font-variant-numeric:tabular-nums}.project-duration{background:#f3e8ff;color:#6b21a8;padding:2px 8px;border-radius:999px}.project-percent{color:#7e22ce}.project-bar{height:8px;border-radius:999px;background:#f8fafc;overflow:hidden;border:1px solid #e2e8f0}.project-bar-fill{height:100%;background:linear-gradient(90deg,#c084fc,#7c3aed);border-radius:999px;transition:width .25s ease}.empty-state{padding:20px;border-radius:12px;background:#f8fafc;color:#64748b;text-align:center;font-size:.88rem}.muted{color:#94a3b8}@media (max-width: 900px){.auth-shell{grid-template-columns:1fr}.auth-side{display:none}.top-nav{flex-direction:column;align-items:flex-start;gap:16px}.nav-buttons{flex-wrap:wrap}.simple-layout,.timer-layout,.daily-layout,.daily-summary,.timeline-row{grid-template-columns:1fr}}@media (max-width: 520px){.history-row{flex-wrap:wrap;gap:6px}}*{box-sizing:border-box}body{margin:0;font-family:Manrope,Segoe UI,sans-serif;color:#0f172a;background:#f8fafc}button,input{font-family:inherit}
