:root{--c-bg: #d4c9b8;--c-surface: #cec3b2;--c-card: #e8dfd2;--c-border: #bfb4a2;--c-text: #2c2419;--c-muted: #7a6e5e;--c-accent: #d4944f;--c-accent-dark: #b07838;--c-warm-bg: #ddd3c3;--c-green: #7a9e5a;--c-shadow: rgba(44, 36, 25, .1);--c-divider: #c4b9a8;--c-focus-ring: rgba(212, 148, 79, .4);--font-display: "Fraunces", Georgia, serif;--font-ui: "Outfit", system-ui, sans-serif;--font-reading: "Lora", Georgia, serif;--font-data: "SF Mono", "Fira Code", "Consolas", monospace;--radius-card: 12px;--radius-btn: 8px;--nav-height: 52px}.playfield-dim{--c-playfield-bg: #1e1812;--c-playfield-surface: #2d261e;--c-playfield-border: #3d3428;--c-playfield-text: #e5d9c5;--c-playfield-muted: #8a7d6a;--c-playfield-target: #e8a34e;--c-playfield-hit: #8fb36a}.playfield-transition{transition:background-color .4s ease-out,color .4s ease-out}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-ui);background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{display:flex;flex-direction:column;min-height:100%}h1,h2,h3{font-family:var(--font-display);font-weight:600}.nav{height:var(--nav-height);background:#c8bfb0;border-bottom:2px solid var(--c-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:100;flex-shrink:0}.nav-brand{font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--c-text);letter-spacing:-.02em;-webkit-user-select:none;user-select:none}.nav-items{display:flex;gap:4px;list-style:none}.nav-btn{display:flex;align-items:center;gap:5px;height:var(--nav-height);padding:0 14px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-family:var(--font-ui);font-size:.8rem;font-weight:500;color:var(--c-muted);opacity:.65;transition:color .15s,opacity .15s,border-color .15s;white-space:nowrap;min-width:48px}.nav-btn:hover{color:var(--c-text);opacity:.9}.nav-btn.active{color:var(--c-accent);border-bottom-color:var(--c-accent);opacity:1}.nav-btn:focus-visible{outline:2px solid var(--c-accent);outline-offset:-2px}.main{flex:1;display:flex;flex-direction:column}.content-container{margin-left:auto;max-width:720px;width:100%;padding:32px 24px}.card{background:var(--c-card);border-radius:var(--radius-card);padding:24px;box-shadow:0 2px 8px #2c241914,0 1px 3px #2c24190d}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:48px;min-width:48px;padding:0 20px;background:var(--c-accent);color:#fff;border:none;border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-ui);font-size:.9rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;transition:background .15s;box-shadow:inset 0 1px #fff3}.btn:hover,.btn:active{background:var(--c-accent-dark)}.btn:focus-visible{outline:2px solid var(--c-accent);outline-offset:2px;box-shadow:0 0 0 4px var(--c-focus-ring)}.btn-ghost{background:transparent;color:var(--c-accent-dark);border:1px solid var(--c-border)}.btn-ghost:hover{background:var(--c-warm-bg);transform:translateY(-1px)}.reading-display{font-family:var(--font-reading);font-size:clamp(18px,2vw,32px);line-height:2;max-width:60ch;margin-left:auto}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 1.5s ease-in-out infinite}.companion-shell{display:flex;flex-direction:column;height:calc(100vh - var(--nav-height) - 64px);background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius-card)}.companion-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--c-border);flex-shrink:0}.companion-title{font-family:var(--font-display);font-size:1.1rem;font-weight:500;color:var(--c-text)}.companion-header-actions{display:flex;gap:8px;align-items:center}.companion-messages{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.companion-msg{max-width:80%;padding:10px 14px;border-radius:12px;font-family:var(--font-reading);font-size:1rem;line-height:1.6;word-break:break-word}.companion-msg.user{align-self:flex-end;background:var(--c-warm-bg);border:1px solid var(--c-border);color:var(--c-text)}.companion-msg.assistant{align-self:flex-start;background:var(--c-surface);border:1px solid var(--c-border);color:var(--c-text)}.companion-msg.error{align-self:flex-start;background:transparent;border:1px solid var(--c-border);color:var(--c-muted);font-style:italic;font-size:.875rem}.companion-thinking{align-self:flex-start;color:var(--c-muted);font-family:var(--font-ui);font-size:.875rem;padding:8px 14px}.companion-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:32px 20px}.companion-empty-label{font-family:var(--font-ui);font-size:.875rem;color:var(--c-muted);text-align:center}.companion-starters{display:flex;flex-direction:column;gap:8px;width:100%;max-width:480px}.companion-starter{background:var(--c-warm-bg);border:1px solid var(--c-border);border-radius:var(--radius-btn);padding:12px 16px;font-family:var(--font-ui);font-size:.9rem;color:var(--c-text);text-align:left;cursor:pointer;min-height:48px;transition:background .15s,border-color .15s}.companion-starter:hover{background:var(--c-surface);border-color:var(--c-accent)}.companion-error-banner{margin:0 20px;padding:10px 14px;background:#f0e0d4;border:1px solid #d4b8a8;border-radius:var(--radius-btn);font-family:var(--font-ui);font-size:.875rem;color:#8b4a2a;flex-shrink:0}.companion-input-row{display:flex;gap:8px;align-items:flex-end;padding:12px 20px 16px;border-top:1px solid var(--c-border);flex-shrink:0}.companion-textarea{flex:1;min-height:48px;max-height:120px;padding:12px 14px;border:1px solid var(--c-border);border-radius:var(--radius-btn);font-family:var(--font-ui);font-size:.95rem;color:var(--c-text);background:var(--c-bg);resize:none;line-height:1.5;transition:border-color .15s}.companion-textarea:focus{outline:none;border-color:var(--c-accent)}.companion-textarea:disabled{opacity:.6;cursor:not-allowed}.companion-send-btn{min-height:48px;min-width:64px;padding:0 16px;background:var(--c-accent);color:#fff;border:none;border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-ui);font-size:.875rem;font-weight:500;transition:background .15s;flex-shrink:0}.companion-send-btn:hover:not(:disabled){background:var(--c-accent-dark)}.companion-send-btn:disabled{opacity:.45;cursor:not-allowed}.companion-voice-btn{min-height:48px;min-width:48px;padding:0 12px;background:transparent;border:1px solid var(--c-border);border-radius:var(--radius-btn);cursor:pointer;font-size:1.1rem;transition:background .15s,border-color .15s}.companion-voice-btn:hover{background:var(--c-warm-bg)}.companion-voice-btn.active{background:var(--c-warm-bg);border-color:var(--c-accent)}.companion-clear-btn{min-height:48px;min-width:48px;padding:0 12px;background:transparent;border:1px solid var(--c-border);border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-ui);font-size:.8rem;color:var(--c-muted);transition:background .15s,color .15s}.companion-clear-btn:hover{background:var(--c-surface);color:var(--c-text)}.home-container{margin-left:auto;max-width:560px;width:100%;padding:32px 24px}.home-heading{font-family:var(--font-display);font-size:2.2rem;font-weight:600;letter-spacing:-.03em;color:var(--c-text);text-shadow:0 1px 0 rgba(255,255,255,.5);margin-bottom:8px}.home-subtext{font-family:var(--font-ui);font-size:.9rem;color:var(--c-muted);margin-bottom:24px;line-height:1.5}.rec-card{background:var(--c-warm-bg);border:none;border-left:5px solid var(--c-accent);border-radius:var(--radius-card);padding:24px;margin-bottom:12px;margin-left:auto;max-width:520px;width:100%;cursor:pointer;transition:background .15s,box-shadow .15s;box-shadow:0 4px 12px #c8875a26,0 2px 4px #2c24190f}.rec-card:hover{background:var(--c-warm-bg)}.rec-card-icon{font-size:1.6rem;margin-bottom:8px}.rec-card-label{font-family:var(--font-display);font-size:1.15rem;font-weight:500;color:var(--c-text);margin-bottom:4px}.rec-card-type{display:inline-block;font-family:var(--font-ui);font-size:.72rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--c-muted);background:var(--c-surface);padding:2px 8px;border-radius:4px;margin-bottom:4px}.rec-card-reason{font-family:var(--font-ui);font-size:.875rem;color:var(--c-muted);line-height:1.4}.rec-fallback{background:var(--c-card);border:1px solid var(--c-border);border-radius:var(--radius-card);padding:16px 24px;margin-bottom:12px;margin-left:auto;max-width:520px;width:100%;cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:12px}.rec-fallback:hover{background:var(--c-warm-bg)}.rec-fallback-label{font-family:var(--font-ui);font-size:.9rem;color:var(--c-text)}.stop-btn{display:block;width:100%;min-height:48px;margin-top:20px;padding:12px 20px;background:transparent;border:1px solid var(--c-muted);border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-ui);font-size:.875rem;color:var(--c-text);transition:color .15s,border-color .15s,background .15s;text-align:center}.stop-btn:hover{color:var(--c-text);background:var(--c-surface);border-color:var(--c-accent)}.summary-card{background:var(--c-card);border-radius:var(--radius-card);padding:24px;margin-bottom:16px;box-shadow:0 2px 8px #2c241914,0 1px 3px #2c24190d}.summary-heading{font-family:var(--font-display);font-size:1.15rem;color:var(--c-text);margin-bottom:12px}.summary-text{font-family:var(--font-reading);font-size:.95rem;color:var(--c-text);line-height:1.7;margin-bottom:12px}.summary-adaptation{padding:10px 14px;background:var(--c-warm-bg);border-left:3px solid var(--c-accent);border-radius:6px;font-size:.875rem;color:var(--c-text);line-height:1.5;margin-bottom:16px}.checkin-card{background:var(--c-card);border-radius:var(--radius-card);padding:28px 24px;box-shadow:0 2px 8px #2c241914,0 1px 3px #2c24190d}.checkin-greeting{font-family:var(--font-display);font-size:1.4rem;color:var(--c-text);margin-bottom:20px}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--c-bg);z-index:300;display:flex;align-items:center;justify-content:center;padding:24px}.onboarding-card{width:100%;max-width:520px;margin-left:auto;background:var(--c-card);border-radius:var(--radius-card);padding:32px 28px;box-shadow:0 2px 8px #2c241914,0 1px 3px #2c24190d}.onboarding-step{font-family:var(--font-ui);font-size:.75rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.onboarding-heading{font-family:var(--font-display);font-size:1.6rem;color:var(--c-text);margin-bottom:16px}.onboarding-body{font-family:var(--font-reading);font-size:.95rem;color:var(--c-text);line-height:1.7;margin-bottom:24px}.day-complete{text-align:center;padding:48px 24px}.day-complete-heading{font-family:var(--font-display);font-size:1.4rem;color:var(--c-text);margin-bottom:12px}.day-complete-text{font-family:var(--font-reading);font-size:.95rem;color:var(--c-muted);line-height:1.6;margin-bottom:24px}.backup-banner{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--c-warm-bg);border:1px solid var(--c-border);border-radius:var(--radius-btn);margin-bottom:16px}.backup-banner-text{flex:1;font-family:var(--font-ui);font-size:.85rem;color:var(--c-text);line-height:1.4}.share-output{font-family:var(--font-ui);font-size:.85rem;color:var(--c-text);white-space:pre-wrap;line-height:1.6;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-btn);padding:16px;max-height:400px;overflow-y:auto}.badge-experimental{display:inline-block;font-family:var(--font-ui);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--c-muted);background:var(--c-surface);border:1px solid var(--c-border);border-radius:4px;padding:2px 8px;margin-left:8px;vertical-align:middle}.history-section{padding:24px 0;border-bottom:1px solid var(--c-divider)}.history-section:first-of-type{padding-top:24px}.history-section:last-of-type{border-bottom:none;padding-bottom:24px}.nav-home-btn{min-height:48px;min-width:48px;padding:0 14px;background:transparent;border:1px solid var(--c-border);border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-ui);font-size:.8rem;color:var(--c-muted);transition:background .15s}.nav-home-btn:hover{background:var(--c-warm-bg)}
