:root{--bg: #0f172a;--bg-elev: #1e293b;--bg-elev-2: #334155;--border: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--accent: #22c55e;--accent-2: #6366f1;--warn: #f59e0b;--danger: #ef4444;--radius: 12px;--radius-lg: 16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color-scheme:dark}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}a{color:var(--accent);text-decoration:none}button{font:inherit}input,textarea,select{width:100%;background:var(--bg-elev);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;font-size:16px;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border-radius:var(--radius);border:1px solid var(--border);background:var(--bg-elev);color:var(--text);cursor:pointer;font-weight:500;min-height:44px;transition:background .15s,transform .05s}.btn:active{transform:scale(.98)}.btn:hover{background:var(--bg-elev-2)}.btn.primary{background:var(--accent);color:#052e16;border-color:var(--accent);font-weight:600}.btn.primary:hover{background:#16a34a}.btn.ghost{background:transparent;border-color:transparent}.btn.danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn.full{width:100%}.btn.small{padding:8px 12px;min-height:36px;font-size:14px}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px}.app-shell{display:flex;flex-direction:column;min-height:100vh;max-width:720px;margin:0 auto}.app-header{position:sticky;top:0;z-index:10;background:#0f172ad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;align-items:center;gap:12px}.app-header h1{margin:0;font-size:18px;flex:1}.app-main{flex:1;padding:16px 16px 96px}.app-tabs{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;background:#0f172af2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid var(--border);padding:8px env(safe-area-inset-right) calc(8px + env(safe-area-inset-bottom)) env(safe-area-inset-left);z-index:10}.app-tabs a{flex:1;text-align:center;padding:8px;color:var(--text-muted);font-size:12px;display:flex;flex-direction:column;align-items:center;gap:2px}.app-tabs a.active{color:var(--accent)}.app-tabs .tab-icon{font-size:22px;line-height:1}.stack{display:flex;flex-direction:column;gap:8px}.stack.loose{gap:12px}.row{display:flex;gap:8px;align-items:center}.row.between{justify-content:space-between}.muted{color:var(--text-muted);font-size:13px}.title{font-size:18px;font-weight:600;margin:0 0 6px}.subtitle{font-size:12px;color:var(--text-muted);margin-bottom:8px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-elev-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.badge.active{background:#22c55e26;color:var(--accent)}.badge.paused{background:#f59e0b26;color:var(--warn)}.badge.done{background:#6366f126;color:var(--accent-2)}.badge.archived{background:#94a3b826;color:var(--text-muted)}.step-row{display:flex;align-items:flex-start;gap:10px;padding:10px;border-radius:var(--radius);background:var(--bg-elev);border:1px solid var(--border)}.step-row .check{width:24px;height:24px;flex-shrink:0;border-radius:50%;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;color:var(--accent);padding:0;margin-top:1px}.step-row .check.checked{background:var(--accent);border-color:var(--accent);color:#052e16}.step-row .check.in-progress{border-color:var(--warn);color:var(--warn)}.step-row.done .step-title{text-decoration:line-through;color:var(--text-muted)}.step-chips{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.step-chip{display:inline-flex;align-items:center;gap:3px;padding:1px 6px;border-radius:999px;font-size:11px;background:var(--bg-elev-2);color:var(--text-muted);white-space:nowrap}.step-chip.warn{background:#f59e0b26;color:var(--warn)}.step-chip.dep{background:#6366f126;color:var(--accent-2)}.material-row{display:flex;align-items:center;gap:8px;padding:6px 0}.material-row .have-check{width:20px;height:20px;flex-shrink:0;border-radius:4px;border:2px solid var(--border);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;color:var(--accent);padding:0}.material-row .have-check.owned{background:var(--accent);border-color:var(--accent);color:#052e16}.material-row.owned .material-name{color:var(--text-muted)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-grid img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px}.fab{position:fixed;right:16px;bottom:80px;width:56px;height:56px;border-radius:50%;background:var(--accent);color:#052e16;font-size:28px;border:none;box-shadow:0 4px 16px #0006;cursor:pointer;z-index:5}.rec-button{width:80px;height:80px;border-radius:50%;border:4px solid var(--danger);background:var(--bg-elev);color:var(--danger);font-size:32px;cursor:pointer}.rec-button.recording{background:var(--danger);color:#fff;animation:pulse 1.2s infinite}@keyframes pulse{0%,to{box-shadow:0 0 #ef4444b3}50%{box-shadow:0 0 0 16px #ef444400}}.toast{position:fixed;bottom:100px;left:50%;transform:translate(-50%);background:var(--bg-elev-2);padding:12px 20px;border-radius:999px;border:1px solid var(--border);z-index:100}.center-screen{min-height:80vh;display:flex;flex-direction:column;justify-content:center;padding:24px;max-width:420px;margin:0 auto}.logo{font-size:32px;font-weight:700;text-align:center;margin-bottom:8px}.logo .accent{color:var(--accent)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.modal-content{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:720px;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-elev);z-index:1}.modal-close{padding:4px 8px!important;min-height:0!important}.modal-body{padding:16px}.auto-textarea{resize:none;overflow:hidden;min-height:44px}.dep-dropdown{position:absolute;left:0;right:0;top:100%;z-index:10;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:0 0 var(--radius) var(--radius);max-height:160px;overflow-y:auto}.dep-dropdown-item{padding:8px 12px;font-size:13px;cursor:pointer;border:none;background:none;color:var(--text);width:100%;text-align:left}.dep-dropdown-item:hover,.dep-dropdown-item:focus{background:var(--bg-elev)}.dep-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:12px;background:#6366f126;color:var(--accent-2)}.dep-tag button{background:none;border:none;color:inherit;cursor:pointer;padding:0;font-size:14px;line-height:1}.journal-step-header{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);padding:8px 0 4px;border-bottom:1px solid var(--border);margin-bottom:8px}.journal-entries{display:flex;flex-direction:column;gap:12px}.journal-entry{border-left:3px solid var(--border);padding-left:12px}.journal-meta{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted);margin-bottom:4px}.journal-badge{padding:1px 6px;border-radius:999px;background:#6366f126;color:var(--accent-2);font-size:10px}.journal-note{border-left-color:var(--accent);cursor:pointer}.journal-note:hover{background:#22c55e08;border-radius:0 var(--radius) var(--radius) 0}.journal-text{font-size:14px;white-space:pre-wrap;line-height:1.5}.journal-photo{border-left-color:var(--accent-2)}.journal-img{width:100%;max-height:400px;object-fit:cover;border-radius:var(--radius);margin-top:4px}.journal-img-placeholder{width:100%;height:120px;background:var(--bg-elev-2);border-radius:var(--radius)}.journal-caption{font-size:12px;color:var(--text-muted);margin-top:4px;font-style:italic}.journal-audio{border-left-color:var(--warn)}.journals-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.journal-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column}.journal-card-cover{width:100%;aspect-ratio:4 / 3;background:var(--bg-elev-2);overflow:hidden}.journal-card-cover img{width:100%;height:100%;object-fit:cover}.journal-card-empty{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:28px}.journal-card-body{padding:8px 10px}.journal-card-preview{font-size:11px;color:var(--text-muted);margin-top:4px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
