@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap";:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}body{margin:0}:root{--bg:#0a0a0f;--bg-card:#12121a;--bg-input:#1a1a25;--bg-hover:#1e1e2a;--text:#e8e8ef;--text-muted:#8888a0;--text-dim:#555568;--border:#2a2a3a;--accent:#6366f1;--accent-glow:#6366f126;--success:#22c55e;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--muted:#6b7280;--font:"Inter", -apple-system, BlinkMacSystemFont, sans-serif;--mono:"JetBrains Mono", monospace;--safe-top:env(safe-area-inset-top,0px);--safe-bottom:env(safe-area-inset-bottom,0px);--safe-left:env(safe-area-inset-left,0px);--safe-right:env(safe-area-inset-right,0px);--tab-height:60px;--header-height:56px}@media (prefers-color-scheme:light){:root{--bg:#f5f5f7;--bg-card:#fff;--bg-input:#f0f0f5;--bg-hover:#e8e8f0;--text:#1a1a2e;--text-muted:#6b6b80;--text-dim:#99a;--border:#d0d0dd;--accent-glow:#6366f114}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{font-family:var(--font);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none;line-height:1.6}.app{min-height:100dvh;padding-top:var(--safe-top);flex-direction:column;display:flex}.main-content{-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--tab-height) + var(--safe-bottom) + 8px);flex:1;animation:.2s fadeIn;overflow-y:auto}@keyframes fadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.task-row,.inv-item,.file-row{animation:.25s both staggerIn}.task-row:first-child{animation-delay:0s}.task-row:nth-child(2){animation-delay:30ms}.task-row:nth-child(3){animation-delay:60ms}.task-row:nth-child(4){animation-delay:90ms}.task-row:nth-child(5){animation-delay:.12s}.inv-item:first-child{animation-delay:0s}.inv-item:nth-child(2){animation-delay:40ms}.inv-item:nth-child(3){animation-delay:80ms}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.loading-bar{top:var(--safe-top);z-index:100;background:var(--bg);height:3px;position:fixed;left:0;right:0}.loading-bar-inner{background:var(--accent);height:100%;animation:1.5s ease-in-out infinite loading}@keyframes loading{0%{width:0%;margin-left:0}50%{width:60%;margin-left:20%}to{width:0%;margin-left:100%}}.error-banner{background:var(--error);color:#fff;cursor:pointer;padding:10px 16px;font-size:13px}.tab-bar{background:var(--bg-card);border-top:1px solid var(--border);padding-bottom:var(--safe-bottom);height:calc(var(--tab-height) + var(--safe-bottom));z-index:50;display:flex;position:fixed;bottom:0;left:0;right:0}.tab-item{color:var(--text-muted);font-size:10px;font-family:var(--font);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:8px 0;font-weight:500;transition:color .2s;display:flex}.tab-item.active{color:var(--accent)}.tab-item svg{transition:transform .2s}.tab-item.active svg{transform:scale(1.1)}.page-header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:10;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:0}.page-header h1{letter-spacing:-.02em;font-size:18px;font-weight:700}.back-btn,.refresh-btn{color:var(--accent);font-size:16px;font-family:var(--font);cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 10px}.back-btn:active,.refresh-btn:active{background:var(--accent-glow)}.setup-prompt{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;height:100dvh;padding:24px;display:flex}.setup-icon{font-size:64px}.setup-prompt h1{background:linear-gradient(135deg, var(--accent), #a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:28px;font-weight:700}.setup-prompt p{color:var(--text-muted);font-size:15px}.btn-primary,.btn-secondary{width:100%;font-family:var(--font);cursor:pointer;border:none;border-radius:12px;padding:14px 20px;font-size:15px;font-weight:600;transition:all .2s;display:block}.btn-primary{background:var(--accent);color:#fff}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{opacity:.5}.btn-secondary{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}.settings-page{padding:0 16px 24px}.settings-section{margin-top:24px}.settings-section h2{color:var(--text);margin-bottom:8px;font-size:16px;font-weight:700}.settings-hint{color:var(--text-muted);margin-bottom:16px;font-size:13px}.field-label{color:var(--text-muted);margin-top:14px;margin-bottom:4px;font-size:13px;font-weight:600;display:block}.field-input{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--mono);border-radius:10px;outline:none;margin-top:4px;padding:12px 14px;font-size:14px;transition:border-color .2s;display:block}.field-input:focus{border-color:var(--accent)}.test-result{border-radius:8px;margin-top:8px;padding:10px 14px;font-size:13px}.test-result.success{color:var(--success);background:#22c55e1a}.test-result.error{color:var(--error);background:#ef44441a}.about-text{color:var(--text-muted);font-size:13px;line-height:1.6}.privacy-note{background:var(--accent-glow);border-radius:10px;margin-top:12px;padding:12px}.file-browser{padding:0}.search-bar{background:var(--bg-card);padding:8px 16px}.search-input{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);border-radius:10px;outline:none;padding:10px 14px;font-size:15px}.search-input:focus{border-color:var(--accent)}.search-input::placeholder{color:var(--text-dim)}.breadcrumb-back{text-align:left;width:100%;color:var(--accent);font-family:var(--font);cursor:pointer;border:none;border-bottom:1px solid var(--border);background:0 0;padding:10px 16px;font-size:14px;display:block}.list-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding:8px 16px;font-size:12px}.file-list{padding-bottom:16px}.file-item{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);text-align:left;cursor:pointer;background:0 0;align-items:center;gap:12px;padding:14px 16px;font-size:15px;transition:background .15s;display:flex}.file-item:active{background:var(--bg-hover)}.file-icon{flex-shrink:0;font-size:20px}.file-info{flex:1;min-width:0}.file-name{white-space:nowrap;text-overflow:ellipsis;font-weight:500;display:block;overflow:hidden}.file-path{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.file-meta{color:var(--text-dim);font-size:12px}.type-badge{color:#fff;text-transform:uppercase;letter-spacing:.03em;border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:10px;font-weight:700}.chevron{color:var(--text-dim);flex-shrink:0;font-size:20px}.empty-state{text-align:center;color:var(--text-muted);padding:40px 24px}.reader-header{border-bottom:1px solid var(--border);background:var(--bg-card);z-index:10;justify-content:space-between;align-items:center;padding:10px 16px;display:flex;position:sticky;top:0}.reader-badges{gap:6px;display:flex}.badge{color:#fff;text-transform:uppercase;border-radius:6px;padding:3px 8px;font-size:10px;font-weight:700}.reader-content{padding:20px 16px 40px}.reader-title{letter-spacing:-.02em;margin-bottom:12px;font-size:24px;font-weight:700;line-height:1.3}.meta-bar{flex-wrap:wrap;gap:12px;margin-bottom:12px;display:flex}.meta-item{color:var(--text-muted);font-size:13px}.tag-list{flex-wrap:wrap;gap:6px;margin-bottom:20px;display:flex}.tag{background:var(--accent-glow);color:var(--accent);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:500}.markdown-body{color:var(--text);font-size:15px;line-height:1.7}.markdown-body h1{margin:24px 0 8px;font-size:22px;font-weight:700}.markdown-body h2{border-bottom:1px solid var(--border);margin:20px 0 8px;padding-bottom:6px;font-size:19px;font-weight:700}.markdown-body h3{margin:16px 0 6px;font-size:16px;font-weight:600}.markdown-body h4,.markdown-body h5,.markdown-body h6{margin:12px 0 4px;font-size:15px;font-weight:600}.markdown-body strong{font-weight:700}.markdown-body code{font-family:var(--mono);background:var(--bg-input);border-radius:4px;padding:2px 6px;font-size:13px}.markdown-body a{color:var(--accent);text-decoration:none}.markdown-body ul,.markdown-body ol{margin:8px 0;padding-left:20px}.markdown-body li{margin:4px 0}.markdown-body blockquote{border-left:3px solid var(--accent);background:var(--accent-glow);color:var(--text-muted);border-radius:0 8px 8px 0;margin:12px 0;padding:8px 14px;font-style:italic}.markdown-body hr{border:none;border-top:1px solid var(--border);margin:24px 0}.checklist-item{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;align-items:flex-start;gap:8px;margin:2px 0;padding:8px 12px;font-size:14px;line-height:1.5;display:flex}.check-icon{flex-shrink:0;font-size:16px;line-height:1.3}.checklist-item.checked{color:var(--text-muted);opacity:.7;text-decoration:line-through}.spacer{height:12px}.markdown-body ol{margin:8px 0;padding-left:24px;list-style:decimal}.markdown-body ol li{margin:4px 0}.image-placeholder{background:var(--bg-input);border:2px dashed var(--border);text-align:center;color:var(--text-dim);border-radius:10px;margin:12px 0;padding:20px;font-size:14px}.image-placeholder small{font-family:var(--mono);color:var(--text-dim);font-size:11px}.code-block{background:var(--bg-input);border:1px solid var(--border);-webkit-overflow-scrolling:touch;border-radius:8px;margin:12px 0;padding:12px 14px;overflow-x:auto}.code-block code{font-family:var(--mono);white-space:pre;background:0 0;padding:0;font-size:12px;line-height:1.5}.table-wrap{-webkit-overflow-scrolling:touch;margin:12px 0;overflow-x:auto}.table-wrap table{border-collapse:collapse;width:100%;font-size:13px}.table-wrap th,.table-wrap td{border:1px solid var(--border);text-align:left;padding:8px 10px}.table-wrap th{background:var(--bg-input);text-transform:uppercase;letter-spacing:.03em;font-size:12px;font-weight:600}.table-wrap tr:nth-child(2n) td{background:var(--bg-card)}.callout{border-left:4px solid;border-radius:8px;margin:12px 0;padding:12px 14px;font-size:13px;line-height:1.5}.callout-note{border-color:var(--info);background:#3b82f614}.callout-tip{border-color:var(--success);background:#22c55e14}.callout-important{border-color:var(--error);background:#ef444414}.callout-warning{border-color:var(--warning);background:#f59e0b14}.callout-caution{border-color:var(--error);background:#ef44441f}.results-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin:16px 0;padding:14px}.results-title{margin-bottom:10px;font-size:14px;font-weight:600}.results-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;display:grid}.result-card{background:var(--bg-input);border-radius:6px;flex-direction:column;gap:2px;padding:8px 10px;display:flex}.result-key{color:var(--text-muted);text-transform:uppercase;font-size:11px;font-weight:500}.result-value{font-size:14px;font-weight:600;font-family:var(--mono)}.linked-section{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:16px;font-size:12px;display:flex}.linked-label{color:var(--text-muted)}.linked-file{background:var(--bg-input);color:var(--accent);border-radius:4px;padding:2px 8px;font-size:11px}.meta-link{color:var(--accent);text-decoration:none}.run-protocol-btn{background:linear-gradient(135deg, var(--accent), #a855f7);color:#fff;width:100%;font-family:var(--font);cursor:pointer;letter-spacing:.02em;border:none;border-radius:12px;margin:16px 0;padding:14px 20px;font-size:16px;font-weight:700;transition:transform .15s,opacity .15s;display:block}.run-protocol-btn:active{opacity:.9;transform:scale(.97)}.protocol-runner{z-index:200;background:var(--bg);padding-top:var(--safe-top);flex-direction:column;display:flex;position:fixed;inset:0}.pr-header{border-bottom:1px solid var(--border);background:var(--bg-card);align-items:center;gap:12px;padding:12px 16px;display:flex}.pr-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:6px;font-size:18px}.pr-title-area{flex:1}.pr-title{font-size:16px;font-weight:700}.pr-subtitle{color:var(--text-muted);font-size:12px}.pr-progress{background:var(--bg-input);height:4px}.pr-progress-fill{border-radius:0 2px 2px 0;height:100%;transition:width .3s}.pr-body{padding:12px 16px;padding-bottom:calc(80px + var(--safe-bottom));-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.pr-materials{border-bottom:1px solid var(--border);margin-bottom:16px;padding-bottom:12px}.pr-materials-toggle{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;cursor:pointer;font-size:12px;font-weight:700;font-family:var(--font);background:0 0;border:none;margin-bottom:6px;padding:4px 0}.pr-material{cursor:pointer;border-radius:6px;align-items:center;gap:8px;padding:6px 8px;font-size:14px;display:flex}.pr-material.checked{color:var(--text-muted);text-decoration:line-through}.pr-material input[type=checkbox]{accent-color:var(--accent);width:18px;height:18px}.pr-material-qty{color:var(--text-muted);background:var(--bg-input);font-size:11px;font-family:var(--mono);border-radius:4px;padding:2px 6px}.pr-step{cursor:pointer;border-radius:10px;margin-bottom:4px;padding:12px;transition:all .15s}.pr-step.active{background:var(--bg-card);border:1px solid var(--border)}.pr-step:not(.active){border:1px solid #0000}.pr-step.completed{opacity:.5}.pr-step-row{align-items:flex-start;gap:10px;display:flex}.pr-checkbox{border:2px solid var(--accent);width:32px;height:32px;color:var(--accent);font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.pr-checkbox.checked{background:var(--success);border-color:var(--success);color:#fff}.pr-step-text{flex:1;padding-top:4px;font-size:15px;line-height:1.5}.pr-step.completed .pr-step-text{color:var(--text-muted);text-decoration:line-through}.pr-timer-row{align-items:center;gap:8px;margin-top:6px;display:flex}.pr-timer-badge{background:var(--bg-input);color:var(--text-muted);font-size:12px;font-family:var(--mono);border-radius:6px;padding:3px 8px;font-weight:600}.pr-timer-badge.running{color:var(--success);background:#22c55e1f;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.pr-timer-btn{border:1px solid var(--accent);background:var(--accent-glow);color:var(--accent);font-size:12px;font-family:var(--font);cursor:pointer;border-radius:6px;padding:3px 10px;font-weight:600}.pr-timer-done{color:var(--success);font-size:12px;font-weight:700}.pr-footer{padding:12px 16px;padding-bottom:calc(12px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--border);align-items:center;gap:8px;display:flex;position:fixed;bottom:0;left:0;right:0}.pr-nav-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-family:var(--font);cursor:pointer;border-radius:8px;padding:10px 16px;font-size:14px;font-weight:600}.pr-nav-btn:disabled{opacity:.3}.pr-nav-btn.primary{background:var(--accent);color:#fff;border-color:var(--accent);flex:1}.pr-step-indicator{color:var(--text-muted);white-space:nowrap;font-size:12px}.pr-complete-overlay{z-index:300;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.pr-complete-card{background:var(--bg-card);text-align:center;border-radius:16px;width:90%;max-width:300px;padding:32px 24px}.pr-complete-icon{margin-bottom:12px;font-size:48px}.pr-complete-card h2{margin-bottom:8px;font-size:22px}.pr-complete-card p{color:var(--text-muted);margin-bottom:20px}.search-panel-mobile{padding:0}.search-stats{color:var(--text-dim);background:var(--bg-input);border-radius:6px;padding:3px 8px;font-size:12px}.search-input-row{padding:8px 16px}.search-chips{-webkit-overflow-scrolling:touch;gap:6px;padding:0 16px 8px;display:flex;overflow-x:auto}.search-chip{border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);font-size:12px;font-family:var(--font);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:4px 10px;transition:all .15s;display:flex}.search-chip.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent);font-weight:600}.search-status,.search-empty,.search-hint{text-align:center;color:var(--text-muted);padding:20px 16px;font-size:13px}.search-count{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;padding:6px 16px;font-size:11px;font-weight:600}.search-results{padding-bottom:16px}.search-result{text-align:left;border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);cursor:pointer;background:0 0;padding:12px 16px;transition:background .15s;display:block}.search-result:active{background:var(--bg-hover)}.search-result-header{align-items:center;gap:8px;display:flex}.search-result-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:600;overflow:hidden}.search-result-title mark{color:var(--accent);background:#6366f140;border-radius:2px;padding:0 2px}.badge-sm{text-transform:uppercase;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:9px;font-weight:700}.status-active{color:var(--success);background:#22c55e1f}.status-draft{color:var(--text-muted);background:#8888a01f}.status-validated{color:var(--accent);background:#6366f11f}.search-result-meta{color:var(--text-muted);margin-top:3px;font-size:12px}.search-result-tags{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.tag-sm{background:var(--accent-glow);color:var(--accent);border-radius:10px;padding:1px 6px;font-size:10px}.search-result-snippet{color:var(--text-dim);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:4px;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.search-result-snippet mark{color:var(--accent);background:#6366f133;border-radius:2px}.search-result-path{color:var(--text-dim);font-size:11px;font-family:var(--mono);margin-top:2px}.tasks-panel-mobile{padding:0}.header-actions{align-items:center;gap:8px;display:flex}.task-count{border-radius:10px;padding:3px 8px;font-size:11px;font-weight:700}.task-count.warning{color:var(--warning);background:#f59e0b1f}.task-count.success{color:var(--success);background:#22c55e1f}.icon-btn{color:var(--accent);cursor:pointer;font-size:20px;font-family:var(--font);background:0 0;border:none;border-radius:6px;padding:4px 8px}.icon-btn:active{background:var(--accent-glow)}.icon-btn:disabled{opacity:.3}.task-filters{-webkit-overflow-scrolling:touch;border-bottom:1px solid var(--border);gap:6px;padding:8px 16px;display:flex;overflow-x:auto}.filter-chip{border:1px solid var(--border);background:var(--bg-input);color:var(--text-muted);font-size:12px;font-family:var(--font);cursor:pointer;white-space:nowrap;border-radius:20px;padding:4px 10px;transition:all .15s}.filter-chip.active{border-color:var(--accent);background:var(--accent-glow);color:var(--accent);font-weight:600}.task-add-form{background:var(--bg-card);border-bottom:1px solid var(--border);padding:12px 16px}.task-add-form input[type=text]{background:var(--bg-input);border:1px solid var(--border);width:100%;color:var(--text);font-family:var(--font);border-radius:8px;outline:none;margin-bottom:8px;padding:10px 14px;font-size:14px}.task-add-form input:focus{border-color:var(--accent)}.task-add-row{align-items:center;gap:8px;display:flex}.task-add-row select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);font-size:13px;font-family:var(--font);border-radius:6px;flex:1;padding:8px}.btn-sm{border-radius:8px;padding:8px 16px;font-size:13px}.task-list{padding:0 0 16px}.task-section{margin-bottom:8px}.task-section-header{text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:6px 16px;font-size:11px;font-weight:700;display:flex}.task-section-count{color:var(--text-muted);font-weight:400}.task-row{border-bottom:1px solid var(--border);align-items:flex-start;gap:10px;padding:12px 16px;transition:background .15s,opacity .3s;display:flex}.task-row:active{background:var(--bg-hover)}.task-row.completed{opacity:.5}.task-row.fading-out{opacity:.3;transition:opacity 1.2s,transform .6s;transform:translate(8px)}.task-checkbox{border:2px solid var(--accent);color:#fff;cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;min-width:22px;height:22px;min-height:22px;margin-top:1px;font-size:12px;font-weight:700;transition:all .2s;display:flex}.task-checkbox.checked{color:#fff;animation:.3s taskCheck;transform:scale(1.1)}@keyframes taskCheck{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1.1)}}.task-content{flex:1;min-width:0}.task-text{font-size:14px;display:block}.task-text.done{color:var(--text-muted);text-decoration:line-through}.task-completed-at{color:var(--success);margin-top:1px;font-size:10px;font-weight:500;display:block}.task-source{color:var(--text-dim);margin-top:2px;font-size:11px;display:block}.task-cat-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.task-delete{color:var(--text-dim);cursor:pointer;opacity:.5;background:0 0;border:none;padding:0 4px;font-size:14px}.task-priority-picker{gap:6px;padding:4px 0;animation:.15s fadeIn;display:flex}.priority-dot{cursor:pointer;border-radius:50%;width:18px;height:18px;transition:transform .15s}.priority-dot:active{transform:scale(1.3)}.priority-dot.active{transform:scale(1.2)}.toast{bottom:calc(70px + var(--safe-bottom));z-index:400;pointer-events:auto;cursor:pointer;border-radius:10px;padding:10px 20px;font-size:13px;font-weight:600;animation:.2s toast-in;position:fixed;left:50%;transform:translate(-50%)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.toast-info{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.toast-success{color:var(--success);border:1px solid var(--success);background:#22c55e26}.toast-error{color:var(--error);border:1px solid var(--error);background:#ef444426}.reader-header-actions{align-items:center;gap:8px;display:flex}.header-icon-btn{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:4px 6px;font-size:20px}.header-icon-btn:active{background:var(--bg-hover)}.checklist-item.interactive{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background .1s}.checklist-item.interactive:active{background:var(--bg-hover)}.version-history{z-index:200;background:var(--bg);padding-top:var(--safe-top);position:fixed;inset:0;overflow-y:auto}.vh-header{border-bottom:1px solid var(--border);background:var(--bg-card);align-items:center;gap:12px;padding:12px 16px;display:flex}.vh-header h2{font-size:16px;font-weight:700}.vh-file-path{color:var(--text-dim);font-size:11px;font-family:var(--mono);background:var(--bg-card);border-bottom:1px solid var(--border);padding:8px 16px}.vh-list{padding:8px 16px}.vh-commit{gap:12px;padding:4px 0;display:flex}.vh-dot-line{flex-direction:column;align-items:center;width:16px;display:flex}.vh-dot{background:var(--border);border-radius:50%;flex-shrink:0;width:10px;height:10px;margin-top:4px}.vh-dot.latest{background:var(--accent)}.vh-line{background:var(--border);flex:1;width:2px}.vh-content{flex:1;padding-bottom:16px}.vh-message{font-size:14px;font-weight:500;line-height:1.4}.vh-meta{color:var(--text-muted);gap:12px;margin-top:4px;font-size:12px;display:flex}.vh-sha{color:var(--text-dim);font-size:11px;font-family:var(--mono);margin-top:2px}.inventory-panel-mobile{padding:0}.inv-add-form{background:var(--bg-card);border-bottom:1px solid var(--border);padding:12px 16px}.inv-add-form input,.inv-add-form select{background:var(--bg-input);border:1px solid var(--border);color:var(--text);font-family:var(--font);border-radius:6px;outline:none;padding:8px 12px;font-size:13px}.inv-add-form input:focus{border-color:var(--accent)}.inv-add-form input[type=text],.inv-add-form input[type=number]{width:100%;margin-bottom:8px}.inv-add-row{gap:8px;margin-bottom:8px;display:flex}.inv-list{padding:0 16px 16px}.inv-item{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin:8px 0;padding:12px;transition:all .2s}.inv-item.expired{border-color:var(--error)}.inv-item.depleted{opacity:.65}.inv-item-header{cursor:pointer;align-items:center;gap:10px;display:flex}.inv-type-badge{letter-spacing:0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:800;display:flex}.inv-type-icon{font-size:20px}.inv-item-info{flex:1;min-width:0}.inv-item-name{font-size:14px;font-weight:600;display:block}.inv-item-location{color:var(--text-muted);font-size:11px;display:block}.inv-item-qty{text-align:right;flex-direction:column;align-items:flex-end;gap:2px;display:flex}.inv-qty-value{font-size:16px;font-weight:700;font-family:var(--mono)}.inv-qty-value.low{color:var(--error)}.inv-qty-bar{background:var(--bg-input);border-radius:2px;height:4px;margin:8px 0 4px;overflow:hidden}.inv-qty-fill{border-radius:2px;height:100%;transition:width .3s}.inv-warning{border-radius:6px;margin-top:4px;padding:4px 8px;font-size:12px}.inv-warning.danger{color:var(--error);background:#ef44441a}.inv-warning.caution{color:var(--warning);background:#f59e0b1a}.inv-details{border-top:1px solid var(--border);margin-top:10px;padding-top:10px;animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:400px}}.inv-detail-row{color:var(--text-muted);padding:3px 0;font-size:12px}.inv-detail-row strong{color:var(--text);margin-right:4px;font-weight:600}.inv-restock-dialog{background:var(--bg-input);border:1px solid var(--accent);border-radius:8px;flex-direction:column;gap:8px;margin-top:10px;padding:10px;display:flex}.inv-actions{gap:8px;margin-top:8px;display:flex}.inv-action-btn{border:1px solid var(--border);background:var(--bg-input);color:var(--text);font-family:var(--font);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:4px;padding:8px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.inv-action-btn:active{transform:scale(.97)}.inv-action-btn:disabled{opacity:.3;pointer-events:none}.inv-action-btn.deplete{border-color:var(--warning);color:var(--warning)}.inv-action-btn.restock{border-color:var(--success);color:var(--success)}.icon{vertical-align:middle;flex-shrink:0;display:inline-block}.inv-action-btn .icon,.header-icon-btn .icon,.icon-btn .icon,.back-btn .icon,.refresh-btn .icon{vertical-align:-2px}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite icon-spin}.task-item,.checklist-item{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:10px;align-items:flex-start;gap:10px;margin:2px 0;padding:10px 12px;font-size:14px;line-height:1.5;transition:all .15s;display:flex}.task-item:active,.checklist-item:active{background:var(--bg-hover);transform:scale(.98)}.task-item.checked,.checklist-item.checked{opacity:.55;color:var(--text-muted);text-decoration:line-through}.task-item .check-icon,.checklist-item .check-icon{flex-shrink:0;margin-top:1px}.task-item .check-icon{color:var(--accent)}.task-item.checked .check-icon{color:var(--success)}.checklist-item .check-icon{color:var(--text-muted)}.checklist-item.checked .check-icon{color:var(--success)}.pdf-viewer{z-index:250;background:var(--bg);padding-top:var(--safe-top);flex-direction:column;display:flex;position:fixed;inset:0}.pdf-header{border-bottom:1px solid var(--border);background:var(--bg-card);flex-shrink:0;align-items:center;gap:10px;padding:10px 16px;display:flex}.pdf-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:8px;display:flex}.pdf-close:active{background:var(--bg-hover)}.pdf-title{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:14px;font-weight:600;overflow:hidden}.pdf-page-info{color:var(--text-muted);font-size:13px;font-family:var(--mono);white-space:nowrap;font-weight:500}.pdf-content{-webkit-overflow-scrolling:touch;background:#1a1a25;flex-direction:column;flex:1;align-items:center;padding:8px;display:flex;overflow:auto}@media (prefers-color-scheme:light){.pdf-content{background:#e8e8ef}}.pdf-canvas{border-radius:4px;max-width:100%;box-shadow:0 2px 12px #0000004d}.pdf-loading{color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;display:flex}.pdf-loading-spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pdf-loading-text{font-size:14px;font-weight:500}.pdf-error{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.pdf-error-icon{width:48px;height:48px;color:var(--error);background:#ef44441f;border-radius:50%;justify-content:center;align-items:center;font-size:24px;font-weight:700;display:flex}.pdf-error-text{color:var(--text-muted);max-width:280px;font-size:14px;line-height:1.5}.pdf-controls{padding:10px 16px;padding-bottom:calc(10px + var(--safe-bottom));background:var(--bg-card);border-top:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;display:flex}.pdf-nav-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:10px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:10px 14px;transition:all .15s;display:flex}.pdf-nav-btn:active:not(:disabled){background:var(--bg-hover);transform:scale(.95)}.pdf-nav-btn:disabled{opacity:.25}.pdf-zoom-controls{background:var(--bg-input);border:1px solid var(--border);border-radius:10px;align-items:center;gap:2px;display:flex;overflow:hidden}.pdf-zoom-btn{color:var(--text);cursor:pointer;min-width:44px;min-height:44px;font-size:16px;font-weight:600;font-family:var(--font);background:0 0;border:none;padding:10px 14px;transition:background .1s}.pdf-zoom-btn:active{background:var(--bg-hover)}.pdf-zoom-pct{font-size:12px;font-family:var(--mono);color:var(--text-muted);text-align:center;min-width:52px}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible),input:focus:not(:focus-visible){outline:none}@keyframes starBounce{0%{transform:scale(1)}30%{transform:scale(1.25)}60%{transform:scale(.9)}to{transform:scale(1)}}.star-bouncing{animation:.35s starBounce}.tab-item{min-height:44px}.offline-banner{top:var(--safe-top);color:var(--warning);text-align:center;z-index:500;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f59e0b26;border-bottom:1px solid #f59e0b33;padding:6px 16px;font-size:12px;font-weight:600;position:fixed;left:0;right:0}
