*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a0f1e;--bg-surface: #231528;--bg-card: #2d1b33;--accent: #c084c4;--accent-soft: #9b59b6;--accent-glow: rgba(192, 132, 196, .15);--gold: #d4a843;--gold-soft: rgba(212, 168, 67, .15);--text: #f0e6f5;--text-muted: #9e85a8;--text-dim: #6b5474;--border: rgba(192, 132, 196, .2);--border-soft: rgba(255,255,255,.06);--danger: #c0392b;--success: #7dcea0;--warn: #e67e22;--radius: 12px;--radius-sm: 8px;--font-serif: "Georgia", "Times New Roman", serif;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-sans)}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-dim);border-radius:2px}h1,h2,h3{font-family:var(--font-serif);font-weight:400;color:var(--text)}h1{font-size:1.6rem;letter-spacing:.08em}h2{font-size:1.2rem;letter-spacing:.04em}h3{font-size:1rem}.serif{font-family:var(--font-serif)}.muted{color:var(--text-muted)}.dim{color:var(--text-dim);font-size:.8rem}.accent{color:var(--accent)}.gold{color:var(--gold)}.screen{flex:1;overflow-y:auto;padding:16px 16px 80px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.card-soft{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius);padding:14px;margin-bottom:10px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--bg-card);border-top:1px solid var(--border);display:flex;height:64px;z-index:100}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--text-dim);font-size:.65rem;letter-spacing:.05em;text-transform:uppercase;transition:color .15s}.nav-item.active{color:var(--accent)}.nav-item .nav-icon{font-size:1.3rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-size:.875rem;font-weight:500;transition:opacity .15s,transform .1s}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent-soft);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent)}.btn-ghost{background:transparent;color:var(--accent);border:1px solid var(--border)}.btn-danger{background:#c0392b33;color:#e74c3c;border:1px solid rgba(192,57,43,.3)}.btn-full{width:100%}textarea,input[type=text],input[type=password]{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-sans);font-size:.9rem;padding:10px 12px;width:100%;resize:none;outline:none;transition:border-color .15s}textarea:focus,input[type=text]:focus,input[type=password]:focus{border-color:var(--accent)}textarea{min-height:80px}.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.7rem;letter-spacing:.05em;text-transform:uppercase;font-weight:600}.badge-pending{background:#e67e2226;color:var(--warn)}.badge-late{background:#c0392b26;color:#e74c3c}.badge-completed{background:#7dcea026;color:var(--success)}.bubble{padding:10px 14px;border-radius:14px;max-width:85%;font-size:.88rem;line-height:1.5;margin-bottom:10px;white-space:pre-wrap}.bubble-user{background:var(--accent-soft);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}.bubble-assistant{background:var(--bg-card);border:1px solid var(--border);color:var(--text);align-self:flex-start;border-bottom-left-radius:4px;font-family:var(--font-serif)}.progress-bar{background:var(--bg-surface);border-radius:999px;height:6px;overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:999px;transition:width .4s ease}.divider{border:none;border-top:1px solid var(--border-soft);margin:12px 0}.login-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:32px;background:var(--bg)}.login-logo{font-family:var(--font-serif);font-size:3rem;letter-spacing:.2em;color:var(--accent)}.login-tagline{font-family:var(--font-serif);font-style:italic;color:var(--text-muted);font-size:.9rem;text-align:center}.obligation-item{border-left:3px solid var(--border);padding-left:12px}.obligation-item.completed{border-color:var(--success);opacity:.65}.obligation-item.late{border-color:var(--danger)}.obligation-item.pending{border-color:var(--accent-soft)}.section-header{font-family:var(--font-serif);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:10px;margin-top:20px}.section-header:first-child{margin-top:0}.vivienne-response{font-family:var(--font-serif);font-style:italic;color:var(--accent);font-size:.85rem;line-height:1.55;padding:10px 12px;background:var(--accent-glow);border-radius:var(--radius-sm);border-left:2px solid var(--accent);margin-top:8px}.outfit-box{background:var(--gold-soft);border:1px solid rgba(212,168,67,.25);border-radius:var(--radius);padding:14px;margin-bottom:14px}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted);font-family:var(--font-serif);font-style:italic}
