:root{color-scheme:dark;--bg: #12151c;--surface: #1a1f28;--surface-raised: #222833;--text: #e8e4dc;--muted: #9a958d;--accent: #c9a962;--accent-soft: #d4bc7a;--struggle: #c49a9a;--neglect: #a67c52;--danger: #d4847a;--nav-h: 4.25rem;--safe-b: env(safe-area-inset-bottom, 0px);--page-x: 1rem;--page-gap: .75rem;--radius: .75rem}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.45}button,input,textarea{font:inherit}.app-shell{min-height:100dvh;display:flex;flex-direction:column}.app-main{flex:1;overflow-y:auto;padding:var(--page-x) var(--page-x) calc(var(--nav-h) + var(--safe-b) + var(--page-x))}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(4,1fr);gap:.2rem;padding:.4rem var(--page-x) calc(.4rem + var(--safe-b));background:color-mix(in srgb,var(--surface) 96%,black);border-top:1px solid color-mix(in srgb,var(--accent) 14%,transparent)}.bottom-nav__link{display:grid;place-items:center;min-height:3rem;padding:.5rem;border-radius:.75rem;color:var(--muted);text-decoration:none;font-size:.8rem;font-weight:600}.bottom-nav__link--active{color:var(--accent-soft);background:color-mix(in srgb,var(--accent) 12%,transparent)}.offline-banner{padding:.5rem 1rem;text-align:center;font-size:.85rem;background:color-mix(in srgb,var(--neglect) 25%,var(--surface));color:var(--text)}.screen{width:100%;max-width:28rem;margin:0 auto}.screen-header{margin-bottom:var(--page-gap)}.screen-header h1{margin:0 0 .2rem;font-size:1.35rem;font-weight:600;letter-spacing:.01em}.muted{color:var(--muted)}.muted.small{font-size:.85rem}.center,.boot{display:grid;place-items:center;min-height:50dvh;padding:2rem}.card{padding:.9rem;border-radius:var(--radius);background:var(--surface);border:1px solid color-mix(in srgb,var(--accent) 12%,transparent)}.stack{display:flex;flex-direction:column;gap:var(--page-gap)}.field{display:flex;flex-direction:column;gap:.35rem;font-size:.85rem;color:var(--muted)}.field input,.field textarea{padding:.75rem .85rem;border-radius:.65rem;border:1px solid color-mix(in srgb,var(--muted) 25%,transparent);background:color-mix(in srgb,var(--bg) 60%,var(--surface));color:var(--text)}.field--grow textarea{min-height:6rem;resize:vertical}.btn{min-height:3rem;padding:.75rem 1rem;border:none;border-radius:.75rem;font-weight:600;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:linear-gradient(145deg,var(--accent-soft),var(--accent));color:#1a1510}.btn--ghost{background:transparent;color:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent)}.btn--danger{width:100%;margin-top:1rem;background:color-mix(in srgb,var(--danger) 20%,var(--surface));color:var(--danger);border:1px solid color-mix(in srgb,var(--danger) 35%,transparent)}.btn--sm{min-height:2.5rem;padding:.5rem .75rem;font-size:.85rem}.error-text{margin:0;color:var(--danger);font-size:.9rem}.hint-banner{margin:0;padding:.75rem .85rem;border-radius:var(--radius);background:color-mix(in srgb,var(--accent) 8%,var(--surface));color:var(--muted);line-height:1.45;font-size:.9rem}.login-screen{min-height:100dvh;display:grid;place-items:center;padding:1.25rem;position:relative;overflow:hidden}.glow{position:absolute;top:10%;left:50%;width:min(28rem,80vw);height:min(28rem,80vw);transform:translate(-50%);border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 28%,transparent),transparent 68%);pointer-events:none}.login-card{position:relative;width:min(100%,24rem);text-align:center}.eyebrow{margin:0 0 .5rem;font-size:.75rem;letter-spacing:.18em;text-transform:uppercase;color:var(--accent-soft)}.domain-block{margin-bottom:1.25rem}.domain-block h2{margin:0 0 .5rem;font-size:1rem;color:var(--accent-soft)}.skill-grid{display:flex;flex-wrap:wrap;gap:.5rem}.skill-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:999px;background:var(--surface);border:1px solid color-mix(in srgb,var(--muted) 20%,transparent);font-size:.85rem}.skill-chip--active{border-color:color-mix(in srgb,var(--accent) 50%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--accent) 35%,transparent)}.skill-chip--struggle{border-color:color-mix(in srgb,var(--struggle) 50%,transparent);box-shadow:0 0 12px color-mix(in srgb,var(--struggle) 30%,transparent)}.skill-chip--neglect{opacity:.45;border-color:color-mix(in srgb,var(--neglect) 40%,transparent)}.skill-chip__meta{color:var(--muted);font-size:.75rem}.proposals-card h2{margin:0 0 .75rem;font-size:1rem}.proposal{margin-bottom:.75rem}.proposal p{margin:0 0 .5rem;font-size:.9rem;color:var(--muted)}.row{display:flex;gap:.5rem}.record-screen{display:flex;flex-direction:column;gap:var(--page-gap)}.record-screen .screen-header{margin-bottom:0}.record-screen .record-actions{display:flex;flex-direction:column;align-items:center;gap:.35rem;margin:.5rem 0}.record-listening{margin:0;text-align:center}.mic-btn{width:4.5rem;height:4.5rem;min-width:72px;min-height:72px;border-radius:50%;border:none;font-size:1rem;font-weight:700;background:linear-gradient(145deg,var(--accent-soft),var(--accent));color:#1a1510;cursor:pointer}.mic-btn--active{background:linear-gradient(145deg,var(--struggle),#b07a7a);color:#1a1510}.follow-up-card ul{margin:0;padding-left:1.1rem;color:var(--text)}.follow-up-card li{margin-bottom:.35rem}.constellation-page{display:flex;flex-direction:column;height:calc(100dvh - var(--nav-h) - var(--safe-b));max-width:none;margin:0}.constellation-toolbar{display:flex;justify-content:flex-end;padding:.4rem var(--page-x) 0;flex-shrink:0}.btn--active{color:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent-soft) 35%,transparent)}.record-date-details{margin-bottom:.75rem}.record-date-details summary{cursor:pointer;padding:.35rem 0}.app-main--canvas{padding-left:0;padding-right:0;padding-top:0;overflow:hidden}.constellation-viewport{flex:1;min-height:0;position:relative}.constellation-canvas{display:block;width:100%;height:100%;touch-action:none;cursor:grab}.constellation-canvas:active{cursor:grabbing}.constellation-overlay{position:absolute;z-index:2;left:var(--page-x);right:var(--page-x);top:.4rem}.proposals-overlay{display:flex;flex-direction:column;gap:.5rem;pointer-events:none}.proposal-pill{pointer-events:auto;display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem .65rem;border-radius:.75rem;background:color-mix(in srgb,var(--surface) 92%,black);font-size:.8rem;color:var(--muted)}.hint-banner--overlay{position:absolute;z-index:2;left:var(--page-x);right:var(--page-x);top:42%;margin:0;text-align:center;pointer-events:none}.timeline{padding:.45rem var(--page-x) 0;border-top:1px solid color-mix(in srgb,var(--accent) 12%,transparent);flex-shrink:0}.timeline__labels{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem}.timeline__range{width:100%;accent-color:var(--accent)}.sheet-backdrop{position:fixed;inset:0;z-index:30;background:#00000073;display:flex;align-items:flex-end;justify-content:center}.sheet{width:min(100%,28rem);max-height:70dvh;overflow-y:auto;padding:.75rem 1rem calc(1rem + var(--safe-b));border-radius:1.25rem 1.25rem 0 0;background:var(--surface);border:1px solid color-mix(in srgb,var(--accent) 15%,transparent)}.sheet__handle{width:2.5rem;height:.25rem;margin:0 auto .75rem;border-radius:999px;background:var(--muted);opacity:.4}.sheet__meta{margin:0 0 .75rem;font-size:.9rem;color:var(--muted)}.sheet__notes ul{margin:.25rem 0 .75rem;padding-left:1rem;font-size:.85rem;color:var(--text)}.sparkline-wrap{margin-bottom:.75rem}.sparkline{width:100%;height:2rem;display:block}.settings-proposal p{margin:0 0 .5rem;font-size:.9rem}.status-success{color:var(--accent-soft)}.status-struggle{color:var(--struggle)}.ask-screen{display:flex;flex-direction:column;min-height:calc(100dvh - var(--nav-h) - var(--safe-b) - 2rem);width:100%}.chat-thread{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:var(--page-gap);margin:0 0 var(--page-gap);min-height:10rem;width:100%}.chat-empty{margin:0;font-size:.9rem;line-height:1.5}.chat-bubble{max-width:92%;padding:.6rem .8rem;border-radius:var(--radius);line-height:1.45;white-space:pre-wrap;word-break:break-word}.chat-bubble--user{align-self:flex-end;background:color-mix(in srgb,var(--accent) 25%,var(--surface))}.chat-bubble--assistant{align-self:flex-start;background:var(--surface);border:1px solid color-mix(in srgb,var(--accent) 12%,transparent)}.chat-bubble--typing{opacity:.8}.ask-compose{display:grid;grid-template-columns:auto 1fr auto;gap:.45rem;align-items:end;width:100%;margin-top:auto;padding-top:.25rem}.ask-compose .field--grow{min-width:0}.ask-compose .field--grow textarea{width:100%;min-height:2.75rem}.mic-btn--small{width:2.75rem;height:2.75rem;font-size:.75rem;flex-shrink:0}.ask-compose__send{flex-shrink:0;min-width:4rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.toast{position:fixed;z-index:40;left:50%;bottom:calc(var(--nav-h) + var(--safe-b) + .75rem);transform:translate(-50%);max-width:min(22rem,calc(100% - 2rem));padding:.65rem 1rem;border-radius:999px;background:color-mix(in srgb,var(--accent-soft) 22%,var(--surface));border:1px solid color-mix(in srgb,var(--accent-soft) 45%,transparent);color:var(--text);font-size:.9rem;text-align:center;box-shadow:0 8px 24px #00000059;animation:toast-in .25s ease-out}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(.5rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}.settings-screen{display:flex;flex-direction:column;gap:var(--page-gap)}.settings-screen .screen-header{margin-bottom:0}.settings-screen .btn--danger{margin-top:0}.settings-section-title{margin:0;font-size:.9rem;font-weight:600;color:var(--accent-soft);letter-spacing:.02em}.archived-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.35rem 0;border-bottom:1px solid color-mix(in srgb,var(--muted) 12%,transparent)}.archived-row:last-of-type{border-bottom:none}
