*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--forest:#1e4636;--forest-deep:#16352a;--forest-light:#235241;--copper:#b0613d;--copper-light:#d89b82;--copper-bg:#f0e4dc;--gold:#d8c4a0;--gold-dark:#b09a5e;--cream:#f4f1ea;--cream-dark:#fbfaf6;--cream-border:#e6e1d6;--cream-bg:#f7f4ed;--parchment:#ece7dc;--sand:#e2dccf;--stone:#9a9387;--stone-dark:#8a857b;--earth:#6e685c;--bark:#5a574e;--ink:#211f1a;--ink-soft:#33312a;--ink-light:#3a382f;--green-soft:#5b9a6e;--green-bg:#e1eadd;--green-light:#eaf0e8;--green-sage:#c9d4c5;--green-muted:#9fb3a4;--green-card:#d8ded2;--tab-inactive:#a39b89;--tab-border:#e2dccf;--font-serif:"Newsreader", serif;--font-mono:"IBM Plex Mono", monospace;--font-system:-apple-system, system-ui, "Segoe UI", sans-serif;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:22px;--radius-pill:20px}html{font-family:var(--font-system);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100vh;color:var(--ink);background:#e9e5db;justify-content:center;align-items:center;display:flex}.phone-frame{background:#1e1c18;border-radius:50px;width:375px;min-height:812px;max-height:812px;padding:10px;position:relative;box-shadow:0 30px 70px -24px #2d261a8c,0 8px 20px #2d261a2e}.phone-screen{background:var(--cream);border-radius:40px;flex-direction:column;width:100%;height:792px;display:flex;position:relative;overflow:hidden}.status-bar{flex:none;justify-content:space-between;align-items:center;height:50px;padding:0 26px;display:flex}.status-bar-icons{align-items:center;gap:6px;display:flex}.status-time{font-family:var(--font-mono);font-size:13px;font-weight:500}.tab-bar{border-top:1px solid var(--tab-border);background:var(--cream-bg);flex:none;justify-content:space-around;align-items:center;height:68px;padding:0 8px 8px;display:flex}.tab-item{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:3px;transition:color .2s;display:flex}.tab-item span{font-family:var(--font-mono);letter-spacing:.03em;font-size:8.5px}.tab-item.active{color:var(--forest)}.tab-item:not(.active){color:var(--tab-inactive)}.screen-content{-ms-overflow-style:none;scrollbar-width:none;flex:1;overflow:hidden auto}.screen-content::-webkit-scrollbar{display:none}.label{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--stone);font-size:10px}.label-sm{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--stone);font-size:9px}.label-xs{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--stone);font-size:9.5px}.card{background:var(--cream-dark);border:1px solid var(--cream-border);border-radius:var(--radius-lg);padding:15px 16px}.card-rounded{background:var(--cream-dark);border:1px solid var(--cream-border);border-radius:var(--radius-xl);padding:20px}.card-dark{background:var(--forest);border-radius:var(--radius-pill);color:#efede3;padding:18px}.avatar{font-family:var(--font-serif);border-radius:50%;justify-content:center;align-items:center;display:flex}.avatar-sm{width:30px;height:30px;font-size:13px}.avatar-md{width:38px;height:38px;font-size:15px}.avatar-lg{width:40px;height:40px;font-size:16px}.progress-track{background:var(--cream-border);border-radius:4px;height:7px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .5s}.heading-lg{font-family:var(--font-serif);color:var(--ink);font-size:27px;line-height:1.05}.heading-md{font-family:var(--font-serif);color:var(--ink);font-size:25px;line-height:1.1}.heading-sm{font-family:var(--font-serif);color:var(--ink);font-size:22px}.btn-primary{background:var(--forest);color:#efede3;border-radius:var(--radius-md);text-align:center;cursor:pointer;border:none;width:100%;padding:13px;font-size:13.5px;font-weight:600;transition:opacity .15s}.btn-primary:active{opacity:.85}.btn-outline{color:#efede3;border-radius:var(--radius-md);text-align:center;cursor:pointer;background:0 0;border:1px solid #efede34d;padding:13px;font-size:13px}.sub-header{flex:none;align-items:center;gap:10px;padding:2px 22px 12px;display:flex}.back-arrow{color:var(--earth);cursor:pointer;font-size:19px;transition:color .15s}.back-arrow:hover{color:var(--ink)}.msg-incoming{align-self:flex-start;max-width:80%}.msg-incoming .bubble{background:var(--cream-dark);border:1px solid var(--cream-border);border-radius:16px 16px 16px 5px;padding:11px 13px;font-size:13px;line-height:1.45}.msg-outgoing{align-self:flex-end;max-width:80%}.msg-outgoing .bubble{background:var(--forest);color:#efede3;border-radius:16px 16px 5px;padding:11px 13px;font-size:13px;line-height:1.45}.msg-time{font-family:var(--font-mono);color:var(--tab-inactive);margin:4px 4px 0;font-size:9px}.segmented{background:var(--parchment);border-radius:13px;padding:3px;display:flex}.segmented-item{text-align:center;cursor:pointer;border-radius:10px;flex:1;padding:8px;font-size:12.5px;transition:all .2s}.segmented-item.active{background:var(--cream-dark);color:var(--ink);font-weight:600;box-shadow:0 1px 2px #3c321e14}.segmented-item:not(.active){color:var(--stone-dark)}.msg-system .bubble{background:#f0e8de;border:1px solid #e4d7c6;border-radius:16px;align-items:flex-start;gap:9px;padding:11px 13px;font-size:13px;line-height:1.45;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-in{animation:.3s forwards fadeIn}.animate-up{animation:.35s forwards slideUp}.stagger-1{opacity:0;animation-delay:50ms}.stagger-2{opacity:0;animation-delay:.1s}.stagger-3{opacity:0;animation-delay:.15s}.stagger-4{opacity:0;animation-delay:.2s}.stagger-5{opacity:0;animation-delay:.25s}.highlight{background:#f6e2b8;border-radius:2px;box-shadow:0 0 0 2px #f6e2b8}@media (width<=600px){body{background:var(--cream)}.phone-frame{width:100vw;min-height:100vh;max-height:100vh;box-shadow:none;background:0 0;border-radius:0;padding:0}.phone-screen{background:0 0;border-radius:0;height:100vh;max-height:100vh}.status-bar{display:none}.screen-content,.sub-header{padding-top:calc(12px + env(safe-area-inset-top,0px))!important}}
