:root{
  --bg:#d8d9c5;
  --panel:#c8c9b3;
  --muted:#6b6d58;
  --text:#2e2f26;
  --accent:#4e5640;
  --ok:#61704f;
  --danger:#a24c4c;
  --shadow:0 8px 18px rgba(46,47,38,.12);
  --toolbar-bg:rgba(230,231,213,.95);
  --toolbar-border:rgba(78,86,64,.25);
  --editor-toolbar-bg:rgba(230,231,213,.85);
  --editor-toolbar-border:rgba(78,86,64,.18);
  --btn-border-color:rgba(78,86,64,.45);
  --btn-bg:rgba(240,241,225,.9);
  --btn-color:var(--accent);
  --btn-hover-bg:rgba(223,224,205,.9);
  --btn-primary-bg:rgba(208,210,189,.9);
  --btn-primary-color:#203354;
  --btn-primary-border:1px solid rgba(78,86,64,.3);
  --btn-danger-bg:rgba(209,176,176,.4);
  --btn-danger-color:#733030;
  --btn-danger-border:1px solid rgba(162,76,76,.4);
  --card-bg:rgba(235,236,221,.8);
  --card-border:rgba(78,86,64,.25);
  --thumb-bg:rgba(216,217,197,.8);
  --canvas-bg:var(--bg);
  --overview-canvas-bg:var(--bg);
  --edge-color:rgba(78,86,64,.72);
  --edge-stroke-width:3;
  --edge-filter:none;
  --node-fill:rgba(236,237,222,.95);
  --node-goal-fill:rgba(212,219,198,.95);
  --node-root-fill:rgba(213,214,195,.95);
  --node-border:rgba(78,86,64,.75);
  --node-goal-border:rgba(71,80,57,.82);
  --node-shadow:0 5px 12px rgba(46,47,38,.1);
  --node-selected-outline:rgba(97,112,79,.5);
  --node-selected-shadow:0 0 0 6px rgba(97,112,79,.15),0 10px 18px rgba(46,47,38,.18);
  --node-timing-fill:rgba(97,112,79,.18);
  --timing-text:var(--text);
  --modal-bg:rgba(236,237,222,.95);
  --modal-border:1px solid rgba(78,86,64,.2);
  --settings-menu-border:rgba(78,86,64,.2);
  --settings-item-hover:rgba(78,86,64,.12);
  --input-bg:rgba(244,245,231,.95);
  --input-border:rgba(78,86,64,.3);
  --input-color:var(--text);
  --nav-hover-bg:rgba(223,224,205,.65);
  --nav-active-bg:rgba(208,210,189,.9);
  --nav-active-border:rgba(78,86,64,.45);
  --nav-active-color:var(--accent);
  --root-text-color:var(--text);
  --timeline-month-bar-top:#6c7358;
  --timeline-month-bar-bottom:#4e5640;
  --plan-plan-bg:rgba(97,112,79,.14);
  --plan-plan-border:rgba(97,112,79,.25);
  --plan-plan-text:var(--accent);
  --plan-ddl-bg:rgba(239,68,68,.12);
  --plan-ddl-border:rgba(239,68,68,.25);
  --plan-ddl-text:#dc2626;
  --plan-time-bg:rgba(80,146,204,.12);
  --plan-time-border:rgba(80,146,204,.25);
  --plan-time-text:#2563eb;
  --plan-outlook-bg:rgba(245,196,86,.16);
  --plan-outlook-border:rgba(245,196,86,.35);
  --plan-outlook-text:#b45309;
  --plan-summary-bg:rgba(56,102,65,.08);
  --plan-summary-border:rgba(56,102,65,.25);
  --plan-summary-text:var(--accent);
}
*{box-sizing:border-box}
html,body{height:100%;margin:0;background:var(--bg);color:var(--text);font:15px/1.5 "Times New Roman",serif;overflow-x:auto} /*overflow-x:hidden*/
a{color:inherit}
.app{min-height:100%;display:grid;grid-template-rows:auto 1fr}
.topbar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--toolbar-bg);backdrop-filter:blur(6px);border-bottom:1px solid var(--toolbar-border);color:var(--accent);width:100%;flex-wrap:wrap;row-gap:.5rem}
.topbar.main-header{position:sticky;top:0;left:0;right:0;z-index:100;width:100vw;background:var(--bg)}
.editor-toolbar{position:static;border-top:1px solid var(--editor-toolbar-border);border-bottom:1px solid var(--editor-toolbar-border);box-shadow:none;background:var(--editor-toolbar-bg)}
.brand{font-weight:700;letter-spacing:.4px}
.global-timer-indicator{display:inline-flex;align-items:center;gap:.4rem;padding:.2rem .65rem;border:1px solid rgba(78,86,64,.3);border-radius:999px;background:rgba(0,0,0,.03);font-size:13px;color:var(--accent);margin-left:1.2rem;flex-shrink:0;max-width:260px}
.global-timer-indicator .timer-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px rgba(78,86,64,.12);animation:pulse 1.2s infinite ease-in-out;flex-shrink:0}
.global-timer-text{font-weight:600;display:flex;align-items:center;gap:.45rem;min-width:0}
.global-timer-text .timer-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.global-timer-text .timer-elapsed{font-variant-numeric:tabular-nums;font-weight:700;white-space:nowrap;flex-shrink:0}
@keyframes pulse{
  0%{transform:scale(.8);opacity:.6}
  50%{transform:scale(1);opacity:1}
  100%{transform:scale(.8);opacity:.6}
}
.btn{appearance:none;border:1px solid var(--btn-border-color);background:var(--btn-bg);color:var(--btn-color);padding:.45rem .75rem;border-radius:10px;cursor:pointer;transition:.15s;box-shadow:none}
.btn.nav-btn{border:none;background:transparent;font-weight:600;font-size:14px}
.btn.nav-btn:hover{background:var(--nav-hover-bg)}
.btn.nav-btn.nav-active{background:var(--nav-active-bg);border:1px solid var(--nav-active-border);color:var(--nav-active-color)}
.btn.nav-btn.nav-active:hover{background:var(--nav-active-bg)}
.review-menu-wrap{position:relative;display:inline-flex}
.review-menu{position:absolute;top:calc(100% + 6px);left:0;background:var(--panel);border:1px solid var(--settings-menu-border);border-radius:12px;box-shadow:var(--shadow);display:none;min-width:150px;padding:.4rem 0;z-index:25}
.review-menu.open{display:block}
.review-menu-item{width:100%;border:none;background:transparent;padding:.55rem .95rem;text-align:left;color:var(--text);font:inherit;cursor:pointer;display:flex;align-items:center;gap:.35rem}
.review-menu-item:hover{background:var(--settings-item-hover)}
.btn:hover{background:var(--btn-hover-bg)}
.btn.active{background:var(--nav-active-bg);color:var(--nav-active-color)}
.btn.primary{border:var(--btn-primary-border);background:var(--btn-primary-bg);color:var(--btn-primary-color)}
.btn.ghost{background:transparent}
.btn.ghost.edit-toggle{border:1px solid var(--btn-border-color);color:var(--btn-color);}
.btn.ghost.edit-toggle.edit-active{background:var(--btn-primary-bg);color:var(--btn-primary-color);border:var(--btn-primary-border)}
.btn.danger{border:var(--btn-danger-border);background:var(--btn-danger-bg);color:var(--btn-danger-color)}
.settings{position:relative}
.settings-btn{padding:.4rem .65rem}
.settings-btn.open{background:var(--btn-hover-bg)}
.settings-menu{position:absolute;right:0;left:auto;top:calc(100% + 6px);background:var(--panel);border:1px solid var(--settings-menu-border);border-radius:12px;box-shadow:var(--shadow);display:none;min-width:180px;padding:.4rem 0;z-index:30}
.settings-menu.open{display:block}
.settings-item{width:100%;border:none;background:transparent;padding:.5rem .9rem;text-align:center;color:var(--text);font:inherit;cursor:pointer;display:flex;justify-content:center;align-items:center}
.settings-item.with-subtext{flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:4px;text-align:left}
.settings-item .settings-item-label{font-weight:600;width:100%}
.settings-item .settings-item-subtext{font-size:12px;color:var(--muted);line-height:1.4;word-break:break-all;text-align:left;width:100%;max-width:220px}
.settings-item:hover{background:var(--settings-item-hover)}
.settings-page{max-width:960px;margin:24px auto;padding:28px 32px;background:var(--panel);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:20px}
.settings-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.settings-page-title{margin:0;font-size:24px;color:var(--accent);font-weight:700}
.settings-page-subtitle{margin:4px 0 0;color:var(--muted)}
.settings-section{background:var(--node-fill);border:1px solid var(--card-border);border-radius:16px;padding:16px 18px;display:flex;flex-direction:column;gap:12px}
.settings-section-title{margin:0;font-size:16px;color:var(--accent);font-weight:700}
.settings-actions{display:flex;gap:10px;flex-wrap:wrap}
.settings-actions.column{flex-direction:column;align-items:flex-start}
.settings-hint{margin:0;color:var(--muted);font-size:13px}
.settings-path-display{padding:10px 12px;border:1px dashed var(--settings-menu-border);border-radius:10px;background:var(--card-bg);color:var(--text);min-width:240px;word-break:break-all}
.toolbar-gap{flex:1}
.main-area{height:calc(100vh - 48px);overflow:auto}
.view{display:none}
.view.active{display:block}
.home-board{max-width:960px;margin:24px auto;padding:28px 32px;background:var(--panel);border:1px solid var(--card-border);border-radius:20px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:24px}
.home-header h1{margin:0;font-size:28px;color:var(--accent);font-weight:700}
.home-header p{margin:8px 0 0;color:var(--muted)}
.home-actions{display:flex;flex-wrap:wrap;gap:12px}
.home-tip{background:var(--node-fill);border:1px solid var(--card-border);border-radius:16px;padding:18px 20px;color:var(--text);box-shadow:var(--shadow)}
.home-tip h2{margin:0 0 10px;font-size:18px;color:var(--accent)}
.home-tip ul{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px;color:var(--muted)}
.home-tip li{line-height:1.5}
.goal-create-bar{display:flex;justify-content:center;align-items:flex-start;gap:12px;padding:24px 12px 28px;flex-wrap:wrap}
.goal-create-label{font-size:26px;font-weight:700;color:var(--accent);min-width:64px;text-align:right}
.goal-create-input{width:480px;min-height:54px;max-height:180px;resize:none;padding:12px 14px;border:1px solid var(--card-border);border-radius:12px;font-size:15px;line-height:1.6;background:var(--panel);color:var(--text);box-shadow:var(--shadow);transition:border .15s ease, box-shadow .15s ease}
.goal-create-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(75,123,236,.18)}
.goal-create-btn{padding:10px 20px;border:none;background:var(--accent);color:#fff;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;box-shadow:var(--shadow);transition:transform .15s ease, filter .15s ease}
.goal-create-btn:hover{transform:translateY(-1px);filter:brightness(.92)}
.goal-manage-bar{display:flex;align-items:center;gap:.75rem;margin:0 auto 16px;flex-wrap:wrap;justify-content:center}
.board{padding:16px;max-width:1100px;margin:0 auto}
.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column;color:var(--accent)}
.thumb{width:100%;height:160px;background:var(--thumb-bg);display:flex;align-items:center;justify-content:center}
.thumb-placeholder{color:var(--muted);}
.thumb img{width:100%;height:100%;object-fit:cover}
.card-body{padding:.75rem}
.card-title{font-weight:700;margin:0 0 .25rem}
.card-meta{color:var(--muted);font-size:12px}
.card-actions{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--divider-color)}
.empty{color:var(--muted);text-align:center;padding:48px 12px}
.editor-wrap{display:grid;grid-template-rows:auto 1fr;height:100%;min-height:0}
.canvas-wrap{position:relative;overflow:auto;height:calc(100vh - 120px);border-top:1px solid var(--divider-color);background:var(--bg);transform-origin:top left;width:100%}
.canvas{position:relative;width:1600px;height:1400px;margin:0;background:var(--canvas-bg);}
.overview-board{height:100%;display:flex;flex-direction:column;flex:1;min-height:0;padding:8px 0 0}
.overview-wrap{flex:1;width:100%;height:100%;cursor:grab;user-select:none;touch-action:pan-x pan-y;background:var(--canvas-bg);overflow:auto;border-radius:0;border:none;box-shadow:none}
.overview-wrap.editing{background-color:var(--canvas-bg);background-image:linear-gradient(var(--grid-line-color,rgba(71,85,105,.08)) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line-color,rgba(71,85,105,.08)) 1px,transparent 1px);background-size:40px 40px;cursor:default}
.overview-wrap.editing .canvas{background-color:transparent}
.overview-wrap.dragging{cursor:grabbing}
html[data-style-mode="logic"] .overview-wrap{cursor:default}
html[data-style-mode="logic"] .overview-wrap.dragging{cursor:grabbing}
.overview-empty{padding:1rem 1.5rem;color:var(--muted);font-size:13px}
.overview-board .node{cursor:default}
.hier-board{max-width:920px;margin:16px auto;padding:16px 0 24px;display:flex;flex-direction:column;gap:12px}
.hier-header{font-weight:700;font-size:18px;color:var(--accent);padding:0 16px}
.hier-empty{color:var(--muted);padding:0 16px}
.hier-list-wrap{overflow:auto;max-height:calc(100vh - 200px);padding:0 16px}
.hier-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.hier-item{position:relative;--indent:0px;margin:0;margin-left:calc(var(--indent,0px) + 8px);background:var(--hier-item-bg,var(--panel));border:1px solid var(--hier-item-border,var(--card-border));border-radius:12px;padding:.6rem 1rem .6rem 2.2rem;color:var(--hier-item-text,var(--text));cursor:pointer;box-shadow:var(--shadow);transition:background .15s,border-color .15s,transform .15s,color .15s}
.hier-item::before,
.hier-item::after {
  display: none !important;
}
.hier-item[data-depth="0"]::before,
.hier-item[data-depth="0"]::after{display:none}
.hier-item:hover{background:var(--hier-item-hover-bg,var(--settings-item-hover))}
.hier-row{position:relative;display:flex;align-items:center;gap:12px;justify-content:space-between;min-height:26px;padding-left:28px}
.hier-connector{position:absolute;left:0;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:999px;background:var(--hier-connector-bg,var(--panel));border:2px solid var(--hier-connector-border,var(--accent));box-shadow:var(--hier-connector-shadow,0 0 0 3px rgba(0,0,0,.05));pointer-events:none;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease,opacity .2s ease}
.hier-item[data-depth="0"] .hier-connector{left:0}
.hier-item .hier-title{font-weight:600;flex:1;color:inherit}
.hier-item .timer{font-size:12px;color:var(--hier-item-meta,var(--muted))}
.hier-item.timing{border-color:var(--ok);background:var(--node-timing-fill);color:var(--timing-text)}
.hier-item.timing::before,
.hier-item.timing::after{background:var(--ok);opacity:.5}
.hier-item.timing .hier-connector{border-color:var(--ok);background:var(--node-timing-fill);box-shadow:0 0 0 3px rgba(47,139,255,.15)}
.hier-item.timing .hier-title{color:var(--timing-text)}
.hier-item.timing .timer{color:var(--timing-text)}
.hier-item.goal-root{
  --hier-item-bg:var(--node-goal-fill);
  --hier-item-border:var(--node-goal-border);
  --hier-item-text:var(--root-text-color,var(--text));
  --hier-item-meta:var(--root-text-color,var(--text));
  --hier-connector-bg:var(--node-goal-fill);
  --hier-connector-border:var(--node-goal-border);
  --hier-item-hover-bg:var(--node-goal-fill);
}
.hier-complete-badge{display:inline-flex;align-items:center;justify-content:center;height:18px;padding:0 .4rem;margin-right:.4rem;font-size:11px;font-weight:600;color:var(--ok);background:rgba(34,197,94,.16);border-radius:999px}
.goal-thumb-list{display:flex;flex-wrap:wrap;gap:16px;padding:0 12px 40px;justify-content:flex-start}
.goal-thumb-card{width:240px;background:var(--panel);border:1px solid var(--card-border);border-radius:14px;box-shadow:var(--shadow);cursor:pointer;overflow:hidden;display:flex;flex-direction:column;transition:transform .15s ease, box-shadow .15s ease}
.goal-thumb-card:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(0,0,0,.16)}
.goal-thumb-card:focus{outline:2px solid var(--accent);outline-offset:3px}
.goal-thumb-preview{width:100%;height:140px;position:relative;background:var(--thumb-bg);display:flex;align-items:center;justify-content:center;overflow:hidden}
.goal-thumb-img{width:100%;height:100%;object-fit:cover;display:block}
.goal-thumb-placeholder{color:var(--muted);font-size:13px}
.goal-thumb-title{padding:10px 14px 14px;font-size:13px;font-weight:600;color:var(--text);line-height:1.4}
.zoom-panel{position:fixed;right:16px;bottom:16px;background:var(--panel);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow);padding:6px 8px;display:flex;align-items:center;gap:6px;z-index:200}
.zoom-panel-btn{appearance:none;border:1px solid var(--btn-border-color);background:var(--btn-bg);color:var(--btn-color);width:32px;height:32px;border-radius:8px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.zoom-panel-btn:hover{background:var(--btn-hover-bg)}
.zoom-panel-input{width:70px;text-align:center;border:1px solid var(--btn-border-color);border-radius:8px;padding:0.25rem 0.35rem;background:var(--panel);color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}
.zoom-panel-input:focus{outline:2px solid var(--accent);outline-offset:2px}
.zoom-panel-input::placeholder{color:var(--muted)}
.time-board{max-width:820px;margin:24px auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:var(--panel);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow);min-height:calc(100vh - 180px)}
.time-header{font-weight:700;font-size:18px;color:var(--accent)}
.time-empty{color:var(--muted);padding:8px 0}
.time-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px;overflow:auto;max-height:calc(100vh - 230px)}
.time-day{background:var(--panel);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow)}
.time-day-header{width:100%;border:none;background:transparent;padding:.6rem 1rem;font-weight:700;color:var(--accent);display:flex;justify-content:flex-start;align-items:center;cursor:pointer}
.time-day-header .time-day-title{display:flex;align-items:center}
.time-day-header .time-day-total{color:var(--muted)}
.time-day-header:hover{background:var(--settings-item-hover)}
.time-day-header .day-label{font-weight:700}
.time-day-header .chevron{transition:transform .2s ease}
.time-day.open .time-day-header .chevron{transform:rotate(90deg)}
.time-day-panel{padding:0 1rem 1rem}
.time-sublist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.time-item{background:var(--node-fill);border:1px solid var(--card-border);border-radius:12px;padding:.75rem 1rem;color:var(--text);display:flex;flex-direction:column;gap:6px;position:relative;padding-right:78px}
.time-item-body{display:flex;flex-direction:column;gap:6px}
.time-item .meta{color:var(--muted);font-size:12px}
.time-item .title{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}
.time-item .title .range{color:var(--muted)}
.time-range-btn{border:none;background:transparent;padding:0;margin:0;color:var(--muted);font:inherit;cursor:pointer;border-radius:4px;text-decoration:none}
.time-range-btn:hover,.time-range-btn:focus-visible{color:var(--text);text-decoration:underline}
.time-range-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.time-item .title .label{font-weight:700;color:var(--text)}
.time-item .duration{color:var(--accent);font-weight:600}
.time-item-delete{position:absolute;top:12px;right:12px;border:1px solid var(--btn-border-color);border-radius:8px;background:transparent;color:var(--danger);padding:.25rem .6rem;font-size:12px;cursor:pointer;transition:background .15s,color .15s}
.time-item-delete:hover{background:rgba(162,76,76,.08);color:#5b1f1f}
.time-summary{padding:12px 16px 16px;background:rgba(0,0,0,.03);border-radius:12px;margin-bottom:14px;border:1px solid rgba(0,0,0,.04)}
.time-summary-heading{margin:0 0 10px;font-size:16px;font-weight:700;color:var(--accent)}
.time-summary-list{display:flex;flex-direction:column;gap:6px}
.time-summary-row{display:flex;align-items:center;gap:10px}
.time-summary-title{width:160px;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.time-summary-bar-wrap{flex:1;height:12px;border-radius:999px;background:rgba(0,0,0,.05);overflow:hidden}
.time-summary-bar{height:100%;background:var(--accent);border-radius:999px}
.time-summary-duration{width:70px;text-align:right;font-size:12px;color:var(--muted)}
.stats-layout{display:grid;grid-template-columns:minmax(230px,260px) minmax(0,1fr);gap:24px;padding:24px;align-items:flex-start}
.stats-calendar{background:var(--panel);border:1px solid var(--card-border);border-radius:16px;padding:16px;box-shadow:var(--shadow)}
.stats-calendar-head{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}
.stats-mode-toggle{display:inline-flex;gap:6px;background:rgba(0,0,0,.04);border-radius:999px;padding:4px}
.stats-mode-btn{flex:1;border:none;background:transparent;border-radius:999px;padding:.35rem 0;font-weight:600;color:var(--muted);cursor:pointer;transition:background .15s,color .15s}
.stats-mode-btn.active{background:var(--btn-primary-bg);color:var(--btn-primary-color);box-shadow:0 6px 12px rgba(0,0,0,.12)}
.stats-calendar-nav{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:var(--accent)}
.stats-nav-btn{border:none;background:transparent;font-size:20px;width:34px;height:34px;border-radius:8px;color:var(--accent);cursor:pointer;transition:background .15s}
.stats-nav-btn:hover{background:var(--nav-hover-bg)}
.stats-calendar-label{font-weight:700;font-size:16px}
.stats-calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;font-size:12px;color:var(--muted);text-align:center;margin-bottom:6px}
.stats-calendar-grid{display:flex;flex-direction:column;gap:6px}
.stats-calendar-row{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;padding:4px;border-radius:14px;transition:background .2s,box-shadow .2s}
.stats-calendar-row.week-active{background:rgba(97,112,79,.08);box-shadow:inset 0 0 0 1px rgba(97,112,79,.1)}
.stats-calendar-cell{position:relative;border:none;background:transparent;border-radius:10px;padding:.7rem .2rem;text-align:center;font:inherit;color:var(--text);cursor:pointer;transition:background .15s,color .15s}
.stats-calendar-cell:hover{background:var(--nav-hover-bg)}
.stats-calendar-cell.inactive{color:var(--muted);opacity:.7}
.stats-calendar-cell.is-today::after{content:'';position:absolute;bottom:6px;left:50%;width:6px;height:6px;border-radius:999px;background:var(--accent);transform:translateX(-50%)}
.stats-calendar-cell.has-records::before{content:'';position:absolute;top:6px;right:8px;width:6px;height:6px;border-radius:999px;background:var(--ok)}
.stats-calendar-cell.is-selected{background:var(--nav-active-bg);color:var(--nav-active-color);box-shadow:0 10px 18px rgba(0,0,0,.16)}
.stats-calendar-cell .date-number{display:block;font-weight:700;font-size:16px;line-height:1}
.stats-content{background:var(--panel);border:1px solid var(--card-border);border-radius:16px;padding:20px 22px 28px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:18px}
.stats-content-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.stats-content-head h2{margin:0;font-size:20px}
.stats-content-head p{margin:4px 0 0;font-size:14px;color:var(--muted)}
.stats-total-chip{min-width:120px;text-align:center;font-weight:700;color:var(--accent);background:rgba(0,0,0,.04);border-radius:999px;padding:.45rem .75rem;border:1px solid rgba(0,0,0,.08)}
.stats-day-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.stats-card{background:var(--node-fill);border:1px solid var(--card-border);border-radius:14px;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:180px}
.stats-card-title{margin:0;font-size:16px;color:var(--accent)}
.stats-list{display:flex;flex-direction:column;gap:10px}
.stats-empty{color:var(--muted);font-size:14px}
.stats-progress-row{display:flex;flex-direction:column;gap:6px;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.05)}
.stats-progress-row:last-child{border-bottom:none;padding-bottom:0}
.stats-progress-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.stats-progress-title{font-weight:600;font-size:14px}
.stats-progress-subtitle{font-size:12px;color:var(--muted)}
.stats-progress-duration{font-size:13px;font-weight:600;color:var(--accent);white-space:nowrap}
.stats-progress-bar{position:relative;height:8px;border-radius:999px;background:rgba(0,0,0,.08);overflow:hidden}
.stats-progress-bar-fill{position:absolute;top:0;left:0;bottom:0;background:var(--accent);border-radius:999px}
.stats-progress-percent{font-size:12px;color:var(--muted);text-align:right}
.stats-note-card{gap:10px}
.stats-note-header{display:flex;align-items:center;justify-content:space-between;gap:12px}
.stats-note-form{display:flex;flex-direction:column;gap:8px}
.stats-note-form input[type="text"]{width:100%;border:1px solid var(--input-border);border-radius:12px;padding:.6rem .75rem;font:inherit;background:var(--input-bg);color:var(--text);line-height:1.4;min-height:44px}
.stats-note-form textarea{width:100%;border:1px solid var(--input-border);border-radius:12px;padding:.6rem .75rem;font:inherit;resize:vertical;background:var(--input-bg);color:var(--text);min-height:80px}
.stats-event-form{flex-direction:row;align-items:flex-start}
.stats-event-form textarea{flex:1;min-height:52px}
.stats-thing-form{flex-direction:column;align-items:stretch}
.stats-thing-form textarea{min-height:96px}
.stats-note-actions{display:flex;justify-content:flex-end;gap:8px}
.stats-note-list{display:flex;flex-direction:column;gap:10px}
.stats-note-item{background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.05);border-radius:12px;padding:.55rem .85rem .55rem .75rem;display:flex;flex-direction:column;gap:4px;position:relative}
.stats-note-delete{appearance:none;border:none;background:transparent;color:var(--muted);font-size:12px;cursor:pointer;opacity:0;transition:opacity .15s,color .15s;padding:2px 4px;position:absolute;top:6px;right:6px}
.stats-note-item:hover .stats-note-delete{opacity:1}
.stats-note-delete:hover{color:var(--danger)}
.stats-note-content{font-size:14px;line-height:1.5;white-space:pre-wrap;word-break:break-word;padding-right:24px}
.stats-note-time-inline{font-size:12px;color:var(--muted);font-weight:600;margin-right:6px;white-space:nowrap;display:inline-block;min-width:68px}
.stats-note-time-clickable{cursor:pointer;color:var(--accent)}
.stats-note-placeholder{color:var(--muted);font-size:13px;line-height:1.6}
.stats-week-wrap{width:100%}
.stats-week-cards{display:grid;grid-template-columns:repeat(7,minmax(140px,1fr));gap:14px;overflow-x:auto;padding-bottom:6px}
.stats-week-card{background:var(--node-fill);border:1px solid var(--card-border);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:8px;min-height:170px}
.stats-week-date{font-weight:600;color:var(--accent);font-size:15px}
.stats-week-total{font-size:13px;color:var(--text)}
.stats-week-tasks{display:flex;flex-direction:column;gap:6px;margin-top:auto}
.stats-week-task{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}
.stats-week-task .value{font-weight:600;color:var(--accent)}
.stats-week-empty{color:var(--muted);font-size:12px}
.timeline-board{max-width:1100px;margin:24px auto;padding:24px;background:var(--panel);border:1px solid var(--card-border);border-radius:22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:20px}
.timeline-header{display:flex;flex-direction:column;gap:12px}
.timeline-header-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}
.timeline-mode-toggle{display:inline-flex;padding:4px;border:1px solid var(--btn-border-color);border-radius:999px;background:rgba(0,0,0,.04);gap:6px}
.timeline-mode-btn{border:none;background:transparent;border-radius:999px;padding:.35rem .9rem;font-weight:600;color:var(--muted);cursor:pointer;transition:background .15s,color .15s}
.timeline-mode-btn.active{background:var(--btn-primary-bg);color:var(--btn-primary-color);box-shadow:0 8px 18px rgba(0,0,0,.12)}
.timeline-controls{display:flex;align-items:center;gap:10px}
.timeline-date-label{font-weight:700;color:var(--accent);min-width:220px;text-align:center}
.timeline-collapse-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.timeline-collapse-label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted)}
.timeline-collapse-select{border:1px solid var(--input-border);border-radius:8px;padding:.2rem .45rem;background:var(--panel);color:var(--text)}
.timeline-collapse-apply{min-width:60px}
.timeline-highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
.timeline-highlight{background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:16px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}
.timeline-highlight-label{font-size:13px;color:var(--muted);letter-spacing:.5px;font-weight:600;text-transform:uppercase}
.timeline-highlight-value{font-size:24px;font-weight:700;color:var(--accent)}
.timeline-highlight-note{font-size:12px;color:var(--muted)}
.timeline-content{display:flex;flex-direction:column;gap:16px}
.timeline-body{background:var(--card-bg);border:1px solid var(--card-border);border-radius:18px;padding:24px;box-shadow:var(--shadow);min-height:320px}
.timeline-month-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 4px}
.timeline-month-nav{display:flex;align-items:center;gap:12px}
.timeline-month-label{font-weight:700;font-size:20px;color:var(--accent);min-width:160px;text-align:center}
.timeline-month-btn{min-width:40px;border-radius:999px}
.timeline-month-today{font-weight:600}
.timeline-month-view{background:var(--card-bg);border:1px solid var(--card-border);border-radius:18px;padding:16px 18px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:10px}
.timeline-month-weekdays{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));text-align:center;font-weight:700;color:var(--muted);font-size:13px;letter-spacing:.2px}
.timeline-month-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}
.timeline-month-cell{background:var(--node-fill);border:1px solid var(--card-border);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:6px;min-height:86px;position:relative;cursor:pointer;transition:transform .15s,box-shadow .15s}
.timeline-month-cell:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(0,0,0,.12)}
.timeline-month-cell.is-muted{opacity:.5}
.timeline-month-cell.is-today{border-color:var(--accent);box-shadow:0 0 0 2px rgba(78,86,64,.25)}
.timeline-month-day{font-weight:700;font-size:15px;color:var(--text)}
.timeline-month-duration{font-size:12px;color:var(--muted);font-weight:600}
.timeline-month-meter{width:100%;flex:1;display:flex;align-items:flex-end;border-radius:14px;background:rgba(0,0,0,.05);margin-top:auto;padding:6px;box-sizing:border-box;overflow:hidden;min-height:120px}
.timeline-month-meter-fill{display:block;width:100%;height:0;border-radius:10px;background:linear-gradient(180deg,var(--timeline-month-bar-top),var(--timeline-month-bar-bottom));box-shadow:0 8px 18px rgba(0,0,0,.15);transition:height .2s ease}
.timeline-month-empty{text-align:center;color:var(--muted);padding:24px 0}
html[data-theme="breeze"]{
  --timeline-month-bar-top:#6c7358;
  --timeline-month-bar-bottom:#4e5640;
}
html[data-theme="cyber"]{
  --timeline-month-bar-top:#7df2ff;
  --timeline-month-bar-bottom:#12abff;
}
html[data-theme="manga"]{
  --timeline-month-bar-top:#fbbf8a;
  --timeline-month-bar-bottom:#f97316;
}
html[data-theme="mangaMale"]{
  --timeline-month-bar-top:#8da2ff;
  --timeline-month-bar-bottom:#4a77ff;
}
html[data-theme="minimal"]{
  --timeline-month-bar-top:#6b7280;
  --timeline-month-bar-bottom:#3f3f46;
}
html[data-theme="colorDark"]{
  --timeline-month-bar-top:#a5b4ff;
  --timeline-month-bar-bottom:#7c3aed;
  --plan-plan-bg:rgba(148,227,173,.16);
  --plan-plan-border:rgba(148,227,173,.45);
  --plan-plan-text:#c5ffd9;
  --plan-ddl-bg:rgba(255,119,119,.14);
  --plan-ddl-border:rgba(255,119,119,.45);
  --plan-ddl-text:#ffb4c0;
  --plan-time-bg:rgba(126,190,255,.28);
  --plan-time-border:rgba(126,190,255,.7);
  --plan-time-text:#e3f1ff;
  --plan-outlook-bg:rgba(255,215,128,.18);
  --plan-outlook-border:rgba(255,215,128,.5);
  --plan-outlook-text:#ffe9b0;
  --plan-summary-bg:rgba(116,200,164,.2);
  --plan-summary-border:rgba(116,200,164,.5);
  --plan-summary-text:#d3ffe9;
}
.timeline-day-list{position:relative;display:flex;flex-direction:column;gap:18px;padding-left:32px}
.timeline-month-empty{text-align:center;color:var(--muted);padding:24px 0}
.timeline-month-empty{text-align:center;color:var(--muted);padding:24px 0}
.timeline-day-list{position:relative;display:flex;flex-direction:column;gap:18px;padding-left:32px}
.timeline-day-list::before{content:'';position:absolute;left:16px;top:8px;bottom:8px;width:2px;background:rgba(0,0,0,.08)}
.timeline-entry{display:grid;grid-template-columns:120px 24px 1fr;gap:12px;align-items:flex-start}
.timeline-entry-time{font-size:13px;color:var(--muted);display:flex;flex-direction:column;gap:4px;font-weight:600}
.timeline-entry-clock{font-size:16px;color:var(--accent)}
.timeline-entry-duration{font-size:12px;color:var(--muted);font-weight:500}
.timeline-entry-marker{display:flex;justify-content:center;position:relative;min-height:18px}
.timeline-entry-marker span{width:14px;height:14px;border-radius:50%;background:var(--accent);box-shadow:0 6px 14px rgba(0,0,0,.15);display:block;margin-top:4px}
.timeline-entry-card{background:var(--node-fill);border:1px solid var(--card-border);border-radius:14px;padding:12px 14px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:6px}
.timeline-entry-title{font-weight:700;font-size:15px;word-break:break-word}
.timeline-entry-meta{font-size:13px;color:var(--muted);display:flex;gap:10px;flex-wrap:wrap}
.timeline-entry-note .timeline-entry-marker span{background:var(--danger)}
.timeline-entry-note .timeline-entry-card{background:rgba(162,76,76,.08);border-color:rgba(162,76,76,.25)}
.timeline-entry-note .timeline-entry-title{color:var(--danger)}
.timeline-entry-note-content{font-size:13px;color:var(--text);line-height:1.5;word-break:break-word}
.timeline-day-empty{text-align:center;color:var(--muted);font-size:14px;padding:24px 0}
.timeline-week-view{background:var(--card-bg);border:1px solid var(--card-border);border-radius:18px;padding:24px;box-shadow:var(--shadow);display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}
.timeline-week-card{background:var(--node-fill);border:1px solid var(--card-border);border-radius:16px;padding:16px;display:flex;flex-direction:column;gap:10px;box-shadow:var(--shadow)}
.timeline-week-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.timeline-week-day{font-weight:700;color:var(--accent)}
.timeline-week-date{font-size:13px;color:var(--muted)}
.timeline-week-total{font-size:13px;color:var(--muted);font-weight:600}
.timeline-week-list{display:flex;flex-direction:column;gap:8px}
.timeline-week-item{display:flex;align-items:flex-start;gap:10px;padding:8px 10px;border-radius:12px;background:rgba(0,0,0,.02);border:1px solid rgba(0,0,0,.04)}
.timeline-week-time{font-size:12px;color:var(--muted);font-weight:600;white-space:nowrap}
.timeline-week-title{font-weight:600;font-size:13px;flex:1;min-width:0;word-break:break-word}
.timeline-week-duration{font-size:12px;color:var(--accent);font-weight:600;white-space:nowrap}
.timeline-week-empty{color:var(--muted);font-size:13px;text-align:center;padding:24px 0;border-radius:12px;background:rgba(0,0,0,.02)}
.timeline-empty{color:var(--muted);text-align:center;padding:4px 0}
.timeline-nav-btn{min-width:42px}
@media (max-width:900px){
  .timeline-entry{grid-template-columns:100px 20px 1fr}
  .timeline-date-label{min-width:160px}
}
@media (max-width:640px){
  .timeline-header-row{flex-direction:column;align-items:flex-start}
  .timeline-entry{grid-template-columns:1fr}
  .timeline-entry-marker{display:none}
  .timeline-day-list{padding-left:0}
  .timeline-day-list::before{display:none}
  .timeline-entry-time{flex-direction:row;justify-content:space-between}
  .timeline-month-controls{flex-direction:column;align-items:flex-start}
  .timeline-month-nav{width:100%}
  .timeline-month-label{flex:1;text-align:left}
}
@media (max-width:960px){
  .stats-layout{grid-template-columns:1fr}
  .stats-week-cards{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
}
svg.edges{position:absolute;inset:0;pointer-events:none}
.edge{stroke:var(--edge-color);stroke-width:var(--edge-stroke-width);fill:none;stroke-linecap:round;stroke-linejoin:round;filter:var(--edge-filter)}
.node{position:absolute;width:200px;max-width:220px;color:var(--text);background:var(--node-fill);border:2px solid var(--node-border);border-radius:16px;padding:.4rem .65rem;user-select:none;cursor:pointer;box-shadow:var(--node-shadow);display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;gap:.2rem;transition:box-shadow .15s,border-color .15s,background .15s}
.node.goal-node{background:var(--node-goal-fill);border-color:var(--node-goal-border)}
html[data-style-mode="free"] .node{transition:left .2s ease,top .2s ease,box-shadow .15s,border-color .15s,background .15s}
html[data-style-mode="free"][data-grab="on"] .node{cursor:grab}
html[data-style-mode="free"][data-grab="on"] .node.is-dragging{cursor:grabbing}
html[data-style-mode="free"] .node.is-dragging{transition:none!important}
.node .title{font-weight:700;font-size:15px;line-height:1.45;white-space:pre-wrap;word-break:break-word}
.node .timer{font-size:13px;color:var(--muted);margin-top:.1rem}
.node.timing{border-color:var(--ok);box-shadow:0 0 0 6px rgba(47,139,255,.1),0 10px 20px rgba(15,152,114,.3);background:var(--node-timing-fill);color:var(--timing-text)}
.node-complete-badge{display:inline-flex;align-items:center;justify-content:center;height:20px;padding:0 .45rem;margin-right:.35rem;font-size:12px;font-weight:600;color:var(--ok);background:rgba(34,197,94,.16);border-radius:999px}
.node.timing .title{color:var(--timing-text)}
.node .meta{display:none;font-size:12px;line-height:1.4;color:var(--muted)}
.node.has-meta .meta{display:block}
.node.root{background:var(--node-root-fill);border-width:3;color:var(--root-text-color,var(--text))}
.node.root .title{font-size:18px;letter-spacing:.3px}
.node.selected{outline:3px solid var(--node-selected-outline);box-shadow:var(--node-selected-shadow)}
.overview-wrap.editing .node{cursor:default}
.overview-wrap.editing .node.editable{cursor:grab}
.overview-wrap.editing .node.dragging{opacity:.6}
.overview-wrap.editing .node.drop-target{outline:2px dashed var(--accent);box-shadow:0 0 0 4px rgba(148,160,255,.25)}
.overview-wrap.editing .node .title.editing{outline:1px solid var(--accent);background:rgba(148,160,255,.12);border-radius:8px;padding:2px 4px;cursor:text}
dialog.modal{border:none;padding:0;border-radius:16px;overflow:hidden;background:var(--modal-bg);color:var(--text);box-shadow:var(--shadow);width:min(520px,92vw);border:var(--modal-border)}
.modal{max-height:85vh}
.modal .content{max-height:60vh;overflow:auto}
.modal header{padding:14px 16px;border-bottom:1px solid var(--divider-color);font-weight:700}
.modal .content{padding:16px}
.modal .actions{display:flex;gap:.5rem;justify-content:flex-end;padding:14px 16px;border-top:1px solid var(--divider-color)}
.field{display:grid;gap:6px;margin-bottom:12px}
.field label{color:var(--muted);font-size:12px}
.field input,.field textarea{width:100%;background:var(--input-bg);color:var(--input-color);border:1px solid var(--input-border);border-radius:10px;padding:.6rem .7rem;font:inherit;resize:vertical}
.field-hint{font-size:12px;color:var(--muted);margin:4px 0 0}
.time-edit-label{font-weight:700;color:var(--text)}
.time-edit-date{font-size:12px;color:var(--muted)}
.plan-board{--plan-week-note-width:150px;width:min(1400px,calc(100vw - 40px));max-width:1400px;margin:0 auto;padding:24px 14px;display:flex;flex-direction:column;gap:14px;min-height:calc(100vh - 200px)}
.plan-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--card-border);border-radius:18px;padding:16px 18px;box-shadow:var(--shadow)}
.plan-hero-text{display:flex;flex-direction:column;gap:6px}
.plan-hero-kicker{margin:0;font-size:12px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase;font-weight:700}
.plan-hero-title{margin:0;font-size:24px;letter-spacing:.3px;color:var(--accent)}
.plan-hero-desc{margin:0;font-size:14px;color:var(--muted)}
.plan-hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.plan-month-nav{display:flex;align-items:center;gap:12px;font-weight:700;font-size:18px;color:var(--accent)}
.plan-month-label{min-width:140px;text-align:center}
.plan-month-btn{padding:.25rem .65rem;border-radius:999px}
.plan-today-btn{font-weight:600}
.plan-legend{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.plan-legend-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;font-weight:700;border:1px solid transparent;cursor:pointer;background:var(--panel);color:var(--muted);transition:.15s}
.plan-legend-btn.active{box-shadow:0 8px 20px rgba(0,0,0,.08)}
.plan-legend-plan{background:var(--plan-plan-bg);color:var(--plan-plan-text);border:1px solid var(--plan-plan-border)}
.plan-legend-plan:not(.active){opacity:.5;filter:saturate(.4)}
.plan-legend-ddl{background:var(--plan-ddl-bg);color:var(--plan-ddl-text);border:1px solid var(--plan-ddl-border)}
.plan-legend-ddl:not(.active){opacity:.5;filter:saturate(.4)}
.plan-legend-time{background:var(--plan-time-bg);color:var(--plan-time-text);border:1px solid var(--plan-time-border)}
.plan-legend-time:not(.active){opacity:.5;filter:saturate(.4)}
.plan-legend-event{background:rgba(255,180,70,.18);color:#b45309;border:1px solid rgba(255,165,0,.35)}
.plan-legend-event:not(.active){opacity:.55;filter:saturate(.6)}
.plan-legend-mood{background:rgba(91,33,182,0.08);color:#5b21b6;border:1px solid rgba(91,33,182,0.2)}
.plan-legend-mood:not(.active){opacity:.5;filter:saturate(.45)}
.plan-legend-thing{background:rgba(34,197,94,.12);color:#0f766e;border:1px solid rgba(16,185,129,.35)}
.plan-legend-thing:not(.active){opacity:.55;filter:saturate(.55)}
.plan-calendar-weekdays{display:grid;grid-template-columns:var(--plan-week-note-width) repeat(7,1fr) var(--plan-week-note-width);text-align:center;font-weight:700;color:var(--muted);font-size:13px;padding:0 6px;gap:12px}
.plan-weeknote-label{color:var(--muted);font-weight:700}
.plan-calendar-grid{display:flex;flex-direction:column;gap:12px;width:100%}
.plan-week-row{display:grid;grid-template-columns:var(--plan-week-note-width) repeat(7,1fr) var(--plan-week-note-width);gap:12px;align-items:stretch}
.plan-calendar-day{border:1px solid var(--card-border);background:var(--panel);border-radius:14px;padding:12px;cursor:pointer;position:relative;font:inherit;color:var(--text);transition:.18s;display:flex;flex-direction:column;align-items:flex-start;gap:10px;min-height:150px;text-align:left}
.plan-calendar-day:hover{box-shadow:0 10px 24px rgba(0,0,0,.12)}
.plan-calendar-day.is-muted{color:var(--muted);opacity:.75}
.plan-calendar-day.is-today{box-shadow:0 8px 28px rgba(97,112,79,.18);border:2px solid var(--accent)}
.plan-calendar-day.in-range{background:rgba(97,112,79,.08)}
.plan-calendar-day.is-selected{border-color:var(--nav-active-border);background:var(--nav-active-bg);color:var(--nav-active-color)}
.plan-day-head{display:flex;align-items:center;justify-content:space-between;width:100%}
.plan-day-number{font-weight:800;font-size:16px;display:flex;align-items:center;gap:6px}
.plan-day-duration{font-size:12px;font-weight:700;color:var(--plan-time-text);background:var(--plan-time-bg);padding:2px 6px;border-radius:999px;line-height:1}
.plan-day-badges{display:flex;flex-direction:column;gap:6px;width:100%;min-height:96px}
.plan-chip{display:flex;align-items:flex-start;gap:6px;padding:6px 8px;border-radius:10px;font-size:12px;line-height:1.4;word-break:break-word;border:1px solid rgba(0,0,0,.04);background:var(--node-fill);width:100%}
.plan-chip-label{font-weight:800;font-size:12px}
.plan-chip-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}
.plan-chip-plan{border-color:var(--plan-plan-border);background:var(--plan-plan-bg)}
.plan-chip-plan .plan-chip-label{color:var(--plan-plan-text)}
.plan-chip-ddl{border-color:var(--plan-ddl-border);background:var(--plan-ddl-bg)}
.plan-chip-ddl .plan-chip-label{color:var(--plan-ddl-text)}
.plan-chip-time{border-color:var(--plan-time-border);background:var(--plan-time-bg)}
.plan-chip-time .plan-chip-label{color:var(--plan-time-text)}
.plan-chip-event{border-color:rgba(255,165,0,.35);background:rgba(255,180,70,.14)}
.plan-chip-event .plan-chip-label{color:#b45309}
.plan-chip-event .plan-chip-text{color:#b45309}
.plan-chip-event-icon{width:18px;height:18px;object-fit:contain;flex-shrink:0;margin-top:2px}
.plan-hide-time .plan-chip-time{display:none}
.plan-hide-event .plan-chip-event{display:none}
.plan-chip-mood{border-color:rgba(91,33,182,0.25);background:rgba(91,33,182,0.05)}
.plan-chip-mood .plan-chip-text{color:#4c1d95}
.plan-hide-mood .plan-chip-mood{display:none}
.plan-chip-thing{border-color:rgba(16,185,129,.35);background:rgba(34,197,94,.12)}
.plan-chip-thing .plan-chip-label{color:#0f766e}
.plan-chip-thing .plan-chip-text{color:#0f766e}
.plan-hide-thing .plan-chip-thing{display:none}
.plan-day-empty{color:var(--muted);font-size:12px;font-style:italic}
.plan-empty{text-align:center;color:var(--muted);padding:20px 0;font-size:14px}
.plan-week-note{border:1px dashed var(--card-border);background:var(--panel);border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:8px;min-height:150px}
.plan-week-note-controls{display:flex;justify-content:center;margin-bottom:4px}
.plan-week-emoji-btn{border:none;background:transparent;border-radius:12px;padding:6px 10px;font-size:26px;cursor:pointer;transition:.12s;box-shadow:none;color:var(--text);display:inline-flex;align-items:center;justify-content:center;min-height:34px;min-width:36px}
.plan-week-emoji-btn:hover{transform:translateY(-1px);opacity:.9}
.plan-week-emoji-btn.is-empty{font-size:18px;color:transparent;pointer-events:auto}
.week-emoji-picker{position:absolute;z-index:9999;background:var(--panel);border:1px solid var(--card-border);border-radius:12px;box-shadow:0 12px 32px rgba(0,0,0,.16);padding:8px;display:grid;grid-template-columns:repeat(6,1fr);gap:6px;max-width:280px}
.week-emoji-option{border:1px solid transparent;background:transparent;padding:6px;cursor:pointer;font-size:18px;border-radius:8px;transition:.1s}
.week-emoji-option:hover{background:var(--nav-active-bg);border-color:var(--nav-active-border)}
.plan-week-note textarea{width:100%;flex:1;min-height:70px;border:1px solid var(--card-border);border-radius:10px;padding:10px;font:inherit;background:var(--input-bg);color:var(--text);resize:vertical;text-align:center}
.plan-week-note-outlook{background:var(--plan-outlook-bg);border-color:var(--plan-outlook-border)}
.plan-week-note-outlook .plan-week-note-title{color:var(--plan-outlook-text)}
.plan-week-note-outlook .plan-week-emoji-btn{color:var(--plan-outlook-text)}
.plan-week-note-outlook textarea{border-color:var(--plan-outlook-border);background:var(--plan-outlook-bg);color:var(--plan-outlook-text);text-align:center}
.plan-week-note-summary{background:var(--plan-summary-bg);border-color:var(--plan-summary-border)}
.plan-week-note-summary .plan-week-note-title{color:var(--plan-summary-text)}
.plan-week-note-summary .plan-week-emoji-btn{color:var(--plan-summary-text)}
.plan-week-note-summary textarea{border-color:var(--plan-summary-border);background:var(--plan-summary-bg);color:var(--plan-summary-text);text-align:center}
.plan-day-dialog{width:520px;max-width:94vw;min-height:60vh}
.plan-day-dialog-head{padding:12px 14px;border-bottom:1px solid var(--divider-color)}
.plan-day-dialog-nav{display:flex;align-items:center;justify-content:space-between;gap:10px}
.plan-day-dialog-nav #planDayDialogDate{font-weight:800;font-size:18px;color:var(--accent);text-align:center;flex:1}
.plan-day-nav-btn{border:1px solid var(--btn-border-color);background:var(--btn-bg);color:var(--btn-color);border-radius:10px;width:36px;height:36px;font-weight:800;cursor:pointer}
.plan-day-dialog .content{padding:14px 16px;display:flex;flex-direction:column;gap:14px}
.plan-day-total{background:var(--node-fill);border:1px solid var(--card-border);border-radius:12px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between}
.plan-day-total-label{font-weight:700;color:var(--muted)}
.plan-day-total-value{font-weight:800;font-size:20px;color:var(--accent)}
.plan-day-section-title{font-weight:700;color:var(--accent);margin-bottom:6px}
.plan-day-bars-list{display:flex;flex-direction:column;gap:8px}
.plan-day-bars-list{background:var(--node-fill);border:1px solid var(--card-border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:10px}
.plan-day-bar-row{display:grid;grid-template-columns:1fr 2.2fr auto;gap:10px;align-items:center}
.plan-day-bar-name{font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text)}
.plan-day-bar-wrap{height:10px;border-radius:999px;background:rgba(0,0,0,.05);overflow:hidden}
.plan-day-bar{height:100%;background:linear-gradient(90deg,var(--plan-time-text),var(--plan-plan-text));opacity:.9;border-radius:999px}
.plan-day-bar-duration{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.plan-day-notes-list{background:var(--node-fill);border:1px solid var(--card-border);border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px}
.plan-day-note{display:flex;align-items:flex-start;gap:10px;padding:6px 0;border-bottom:1px dashed rgba(0,0,0,.08);line-height:1.5;color:var(--text)}
.plan-day-note:last-child{border-bottom:none}
.plan-day-note-time{font-weight:700;color:var(--muted);font-variant-numeric:tabular-nums;min-width:54px;text-align:right}
.plan-day-note-text{flex:1;min-width:0;word-break:break-word}
.plan-day-note-title{font-weight:700;margin-bottom:4px}
.plan-day-event-icon{width:18px;height:18px;object-fit:contain;vertical-align:middle;margin-right:6px}
.plan-day-dialog section.hidden{display:none}
.plan-day-empty{color:var(--muted);font-size:13px}
.ddl-board{padding:24px;min-height:calc(100vh - 200px);display:flex;flex-direction:column;gap:18px}
.ddl-header{background:var(--panel);border:1px solid var(--card-border);border-radius:18px;padding:20px;box-shadow:var(--shadow);display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ddl-title{margin:0;font-size:22px;color:var(--accent)}
.ddl-subtitle{margin:6px 0 0;color:var(--muted);font-size:14px;max-width:520px}
.ddl-summary{font-weight:700;font-size:16px;color:var(--accent)}
.ddl-list{display:flex;flex-direction:column;gap:14px}
.ddl-empty{background:var(--panel);border:1px solid var(--card-border);border-radius:18px;padding:48px 24px;text-align:center;color:var(--muted);font-size:15px;box-shadow:var(--shadow)}
.ddl-item{display:flex;align-items:center;gap:18px;padding:16px 20px;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow)}
.ddl-item-count{min-width:90px;text-align:center;font-weight:800;font-size:24px;color:var(--accent);font-variant-numeric:tabular-nums}
.ddl-item-count.is-overdue{color:var(--danger)}
.ddl-item-time{display:flex;flex-direction:column;gap:6px;min-width:140px}
.ddl-item-countdown{font-size:14px;color:var(--muted)}
.ddl-item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}
.ddl-item-title{font-weight:700;font-size:17px;margin:0;word-break:break-word}
.ddl-item-meta{color:var(--muted);font-size:13px}
.ddl-item-deadline{font-size:13px;color:var(--accent);font-variant-numeric:tabular-nums}
.ddl-item-status{padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;align-self:flex-start}
.ddl-item-status.is-soon{background:rgba(255,196,0,.18);color:#b45309}
.ddl-item-status.is-overdue{background:rgba(162,76,76,.15);color:var(--danger)}
.ddl-item-status.is-safe{background:rgba(97,112,79,.18);color:var(--accent)}
.ddl-item-footer{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.ddl-item-path{font-size:13px;color:var(--muted)}
.ddl-item-row{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap}
.ddl-list.compact .ddl-item{flex-direction:column;align-items:flex-start}
.ddl-list.compact .ddl-item-time{flex-direction:row;align-items:center}
.ddl-list.compact .ddl-item-count{min-width:auto;font-size:20px}
.ddl-list.compact .ddl-item-countdown{font-size:13px}
@media (max-width:720px){
  .ddl-board{padding:16px}
  .ddl-item{flex-direction:column;align-items:flex-start}
  .ddl-item-time{flex-direction:row;align-items:center;gap:10px}
  .ddl-item-count{min-width:auto}
}
.hint{color:var(--muted);font-size:12px;margin-left:auto}
.footer-note{color:var(--muted);font-size:12px;padding:.5rem 1rem}
.theme-options{display:flex;flex-direction:column;gap:.5rem;padding:.5rem 0}
.theme-option{border:1px solid var(--settings-menu-border);background:transparent;padding:.55rem .9rem;border-radius:10px;font:inherit;color:var(--text);cursor:pointer;display:flex;justify-content:center;align-items:center}
.theme-option:hover{background:var(--settings-item-hover)}
.theme-option.active{border:2px solid var(--accent);background:var(--settings-item-hover)}
@media (max-width:660px){
  .topbar{flex-wrap:wrap}
  .plan-board{--plan-week-note-width:110px;padding:22px 12px}
  .plan-week-note textarea{min-height:80px}
  .home-board{padding:24px 18px}
  .home-actions{flex-direction:column;align-items:stretch}
  .goal-create-bar{flex-direction:column;align-items:stretch}
  .goal-create-label{text-align:left}
  .goal-create-input{width:100%}
  .goal-manage-bar{flex-direction:column;align-items:stretch}
  .goal-thumb-list{justify-content:center}
  .goal-thumb-card{width:100%;max-width:320px}
  .mail-board{padding:16px 12px}
  .mail-item{padding:14px 16px}
  .mail-meta{flex-direction:column;align-items:flex-start;gap:6px}
  .mail-detail-internal{margin:0 -4px}
  .mail-detail-head{flex-direction:column;align-items:flex-start;gap:10px}
  .mail-detail-meta{width:100%}
  .mail-detail-card .mail-delete-btn{align-self:flex-start}
  .achievement-toast{bottom:20px;left:20px;right:20px;max-width:none}
  .achievement-content{padding:10px 20px}
  .achievement-title{font-size:14px}
  .plan-board{grid-template-columns:1fr;padding:16px}
}
.hier-day{background:var(--panel);border:1px solid var(--card-border);border-radius:12px;box-shadow:var(--shadow)}
.mail-board{max-width:920px;margin:24px auto;padding:20px 16px;display:flex;flex-direction:column;gap:16px;background:var(--panel);border:1px solid var(--card-border);border-radius:16px;box-shadow:var(--shadow);min-height:calc(100vh - 180px)}
.mail-header{font-weight:700;font-size:20px;color:var(--accent);padding:0 4px 8px;border-bottom:2px solid var(--card-border);margin-bottom:4px}
.mail-empty{color:var(--muted);text-align:center;padding:48px 12px;font-size:14px}
.mail-list{display:flex;flex-direction:column;gap:12px;overflow:auto;max-height:calc(100vh - 230px);padding:4px 0}
.mail-item{background:var(--node-fill);border:1px solid var(--card-border);border-radius:14px;padding:16px 18px;cursor:pointer;box-shadow:var(--shadow);transition:all .2s ease;position:relative;display:flex;flex-direction:column;gap:10px}
.mail-item::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent);border-radius:14px 0 0 14px;opacity:0;transition:opacity .2s ease}
.mail-item:hover{background:var(--settings-item-hover);transform:translateX(4px);box-shadow:0 6px 20px rgba(0,0,0,.15)}
.mail-item:hover::before{opacity:1}
.mail-item.active{border-color:var(--accent);box-shadow:0 0 0 2px rgba(148,160,255,.35),0 6px 18px rgba(0,0,0,.18)}
.mail-item.unread{background:rgba(97,112,79,.08);border-color:rgba(97,112,79,.3)}
.mail-item.unread::before{opacity:1;background:var(--ok)}
.mail-item.unread::after{content:"";position:absolute;right:18px;top:18px;width:10px;height:10px;background:var(--ok);border-radius:50%;box-shadow:0 0 0 2px var(--node-fill)}
.mail-title{font-weight:700;font-size:16px;color:var(--text);line-height:1.4;margin:0;display:flex;align-items:center;gap:8px}
.mail-item.unread .mail-title{color:var(--accent)}
.mail-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.mail-meta .sender{font-size:13px;color:var(--muted);font-weight:500}
.mail-meta .date{font-size:12px;color:var(--muted);white-space:nowrap}
.mail-detail-internal{display:none;background:var(--card-bg);border:1px solid var(--card-border);border-radius:16px;padding:0;box-shadow:var(--shadow);overflow:auto}
.mail-detail-internal.open{display:block}
.mail-detail-card{display:flex;flex-direction:column;gap:0}
.mail-detail-head{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--card-border);gap:12px;flex-wrap:wrap}
.mail-detail-meta{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.mail-detail-title{font-weight:700;font-size:18px;color:var(--accent);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.mail-detail-date{font-size:13px;color:var(--muted)}
.mail-detail-body{padding:20px 22px;display:flex;flex-direction:column;gap:12px;line-height:1.7;font-size:15px;color:var(--text)}
.mail-detail-body h3{margin:12px 0 6px;font-size:16px}
.daily-review-greeting{margin:0;font-weight:600}
.daily-review-topline{margin:0}
.daily-review-topline .highlight{color:var(--accent);font-weight:700}
.daily-review-total{margin:0}
.daily-review-total strong{color:var(--accent);font-weight:700}
.daily-review-section{background:var(--panel);border:1px solid var(--card-border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.daily-review-summary{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.daily-review-summary li{display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:600;flex-wrap:wrap}
.daily-review-summary li{flex-direction:column;align-items:stretch;gap:6px}
.daily-review-row{display:flex;justify-content:space-between;align-items:center;gap:16px;font-weight:600;flex-wrap:wrap}
.daily-review-task{flex:1;min-width:0;word-break:break-word}
.daily-review-time{color:var(--muted);font-size:13px;white-space:nowrap;margin-left:auto}
.daily-review-bar-wrap{width:100%;height:8px;border-radius:999px;background:var(--settings-item-hover);overflow:hidden}
.daily-review-bar{height:100%;border-radius:999px;background:var(--accent)}
.daily-review-summary-empty{color:var(--muted);font-style:italic}
.daily-review-motivation{margin:0;font-weight:600;color:var(--accent)}
.mail-detail-card .mail-delete-btn{color:var(--btn-danger-color,var(--danger,#a24c4c));border-color:var(--btn-danger-border,var(--danger,#a24c4c));background:transparent}
html[data-theme="minimal"] .mail-detail-card .mail-delete-btn{color:#e25555;border-color:rgba(226,85,85,.55);background:rgba(226,85,85,.1)}
html[data-theme="cyber"] .mail-detail-card .mail-delete-btn{color:#ff4e88;border-color:rgba(255,78,136,.65);background:rgba(255,78,136,.12)}
html[data-theme="colorDark"] .mail-detail-card .mail-delete-btn{color:#ff7f9d;border-color:rgba(255,127,157,.6);background:rgba(255,127,157,.12)}
.achievement-toast{position:fixed;bottom:32px;left:32px;transform:translateY(20px) scale(0.9);opacity:0;z-index:10000;pointer-events:none;transition:all .4s cubic-bezier(.68,-0.55,.265,1.55)}
.achievement-toast.show{transform:translateY(0) scale(1);opacity:1}
.achievement-content{background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(250,250,255,.98));border:2px solid transparent;border-radius:16px;padding:12px 24px;box-shadow:0 8px 24px rgba(0,0,0,.2),0 2px 8px rgba(138,43,226,.15);display:flex;flex-direction:row;align-items:center;justify-content:center;position:relative;overflow:visible;backdrop-filter:blur(10px)}
.achievement-title{font-size:16px;font-weight:600;color:var(--text);letter-spacing:0.5px;white-space:nowrap;line-height:1.4}
.achievement-name{font-weight:700;background:linear-gradient(135deg,#8a2be2,#ff1493,#ff6347);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.achievement-star{position:absolute;z-index:10001}
html[data-theme="cyber"] .achievement-content{background:linear-gradient(135deg,rgba(6,9,18,.98),rgba(12,16,29,.98));border-color:rgba(125,242,255,.3);box-shadow:0 8px 24px rgba(0,0,0,.6),0 2px 8px rgba(125,242,255,.25)}
html[data-theme="cyber"] .achievement-title{color:#e5f9ff}
html[data-theme="cyber"] .achievement-name{background:linear-gradient(135deg,#7df2ff,#14ffb8,#12abff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
html[data-theme="colorDark"] .achievement-content{background:linear-gradient(135deg,rgba(25,26,31,.98),rgba(31,32,38,.98));border-color:rgba(148,160,255,.3);box-shadow:0 8px 24px rgba(0,0,0,.7),0 2px 8px rgba(148,160,255,.25)}
html[data-theme="colorDark"] .achievement-title{color:#f5f7ff}
html[data-theme="colorDark"] .achievement-name{background:linear-gradient(135deg,#94a0ff,#7dd7a5,#8c9cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.goal-stats-board{max-width:1040px;margin:28px auto;padding:20px;background:var(--panel);border:1px solid var(--card-border);border-radius:18px;box-shadow:var(--shadow)}
.goal-stats-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.goal-stats-title{margin:0;font-size:22px;color:var(--accent)}
.goal-stats-subtitle{margin:4px 0 0;color:var(--muted);font-size:14px}
.goal-stats-chart-wrap{background:rgba(255,255,255,.35);border:1px solid var(--card-border);border-radius:14px;padding:16px;min-height:360px;display:flex;align-items:center;justify-content:center;position:relative}
.goal-stats-empty{color:var(--muted);text-align:center}
.goal-stats-meta{margin-top:10px;color:var(--muted);font-size:13px}
.stats-event-form{display:flex;gap:12px;align-items:flex-start}
.stats-event-icon-trigger-wrap{position:relative}
.stats-event-icon-trigger{width:52px;height:52px;border:1px solid var(--btn-border-color);background:var(--btn-bg);border-radius:12px;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;box-shadow:none}
.stats-event-icon-thumb{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.stats-event-icon-thumb img{width:32px;height:32px;object-fit:contain}
.stats-event-icon-thumb.empty{background:rgba(0,0,0,.02);border-radius:10px}
.stats-event-icon-popup{position:absolute;top:110%;left:0;z-index:40;display:none;gap:8px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--card-border);border-radius:12px;padding:10px;box-shadow:var(--shadow);max-width:420px;max-height:260px;overflow:auto}
.stats-event-icon-popup.open{display:flex}
.stats-event-icon-btn{border:1px solid var(--btn-border-color);background:var(--btn-bg);border-radius:10px;padding:6px;cursor:pointer;transition:.12s;box-shadow:none}
.stats-event-icon-btn img{width:32px;height:32px;display:block;object-fit:contain}
.stats-event-icon-btn.active{border-color:var(--nav-active-border);background:var(--nav-active-bg);box-shadow:0 0 0 2px rgba(78,86,64,.15)}
.stats-event-content{display:flex;align-items:flex-start;gap:8px}
.stats-event-icon{width:24px;height:24px;object-fit:contain;flex-shrink:0;margin-top:2px}
