@import"https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,500;0,9..144,600;1,9..144,400&family=Geist:wght@300;400;500;600&display=swap";:root{--bg: #0e1118;--surface: #161b27;--surface2: #1e2535;--border: rgba(255,255,255,.07);--border2: rgba(255,255,255,.12);--text: #e2e8f0;--muted: #64748b;--muted2: #94a3b8;--teal: #2dd4bf;--teal-dim: rgba(45,212,191,.12);--amber: #fbbf24;--amber-dim: rgba(251,191,36,.12);--red: #f87171;--red-dim: rgba(248,113,113,.12);--green: #4ade80;--green-dim: rgba(74,222,128,.1)}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);font-family:Geist,sans-serif;color:var(--text);min-height:100vh}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:220px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;z-index:20}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.sidebar-logo h1{font-family:Fraunces,serif;font-size:20px;font-weight:500;color:var(--text);letter-spacing:-.5px}.sidebar-logo p{font-size:11px;color:var(--muted);margin-top:2px;font-weight:300}.sidebar-nav{flex:1;padding:12px 10px;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;cursor:pointer;font-size:13.5px;font-weight:400;color:var(--muted2);transition:all .15s;border:1px solid transparent;-webkit-user-select:none;user-select:none}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--surface2);color:var(--text);border-color:var(--border2)}.nav-item .icon{font-size:16px;width:20px;text-align:center}.nav-badge{margin-left:auto;background:var(--teal);color:#000;font-size:10px;font-weight:600;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.sidebar-cases{padding:12px 10px;border-top:1px solid var(--border)}.sidebar-cases-label{font-size:10px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;padding:0 12px 8px}.case-chip{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:12.5px;color:var(--muted2);transition:all .15s;truncate:ellipsis}.case-chip:hover,.case-chip.active{background:var(--surface2);color:var(--text)}.case-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.case-chip-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.main{flex:1;display:flex;flex-direction:column;overflow:hidden}.topbar{height:56px;flex-shrink:0;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 24px;gap:0;overflow:hidden}.topbar-title-group{display:flex;align-items:baseline;min-width:0;flex:1;overflow:hidden}.topbar h2{font-family:Fraunces,serif;font-size:18px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0}.topbar-sub{font-size:12px;color:var(--muted);margin-left:10px;white-space:nowrap;flex-shrink:0}.topbar-actions{margin-left:auto;flex-shrink:0;display:flex;gap:8px}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.scroll-view{flex:1;overflow-y:auto;min-height:0}.scroll-view::-webkit-scrollbar{width:4px}.scroll-view::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:none;font-family:Geist,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-primary{background:var(--teal);color:#000}.btn-primary:hover{filter:brightness(1.1)}.btn-ghost{background:transparent;color:var(--muted2);border:1px solid var(--border2)}.btn-ghost:hover{background:var(--surface2);color:var(--text)}.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid rgba(248,113,113,.2)}.btn-danger:hover{background:#f8717133}.btn-sm{padding:5px 10px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed}.chat-view{display:flex;flex-direction:column;flex:1;min-height:0}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px;min-height:0}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:2px}.msg{display:flex;gap:12px;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg.user{flex-direction:row-reverse}.msg-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:2px}.msg-avatar.ai{background:linear-gradient(135deg,#2dd4bf,#34d399);font-size:13px}.msg-avatar.user{background:#6366f133;border:1px solid rgba(99,102,241,.3)}.msg-bubble{max-width:75%;padding:12px 16px;border-radius:14px;font-size:14px;line-height:1.65;font-weight:300}.msg-bubble.ai{background:var(--surface2);border:1px solid var(--border);border-top-left-radius:4px;color:var(--text)}.msg-bubble.user{background:#6366f126;border:1px solid rgba(99,102,241,.25);border-top-right-radius:4px;color:#c7d2fe}.msg-case-preview{background:var(--surface);border:1px solid var(--teal);border-radius:12px;padding:16px;margin-top:8px}.msg-case-preview h4{font-family:Fraunces,serif;font-size:15px;color:var(--teal);margin-bottom:8px}.msg-case-preview p{font-size:13px;color:var(--muted2);line-height:1.5}.chat-input-area{border-top:1px solid var(--border);padding:16px 24px;background:var(--surface)}.chat-input-row{display:flex;gap:10px;align-items:flex-end}.chat-textarea{flex:1;background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:12px 16px;color:var(--text);font-family:Geist,sans-serif;font-size:14px;font-weight:300;resize:none;outline:none;min-height:48px;max-height:120px;line-height:1.5;transition:border-color .2s}.chat-textarea::placeholder{color:var(--muted)}.chat-textarea:focus{border-color:#2dd4bf66}.send-btn{width:48px;height:48px;border-radius:12px;background:var(--teal);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#000;flex-shrink:0;transition:all .15s}.send-btn:hover{filter:brightness(1.1)}.send-btn:disabled{opacity:.35;cursor:not-allowed}.typing{display:flex;gap:4px;align-items:center;padding:4px 0}.typing span{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:blink 1.2s infinite}.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.dashboard-grid{padding:24px;display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.case-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;cursor:pointer;transition:all .2s}.case-card:hover{border-color:var(--border2);transform:translateY(-1px)}.case-card-header{padding:16px 18px 12px;display:flex;align-items:flex-start;gap:12px}.case-color-bar{width:4px;border-radius:4px;align-self:stretch;flex-shrink:0;min-height:32px}.case-card-title{font-family:Fraunces,serif;font-size:16px;font-weight:500;line-height:1.3}.case-card-sub{font-size:12px;color:var(--muted);margin-top:3px}.case-card-body{padding:0 18px 16px}.today-progress{display:flex;align-items:center;gap:8px;margin-bottom:12px}.progress-bar-wrap{flex:1;height:5px;background:#ffffff12;border-radius:3px;overflow:hidden}.progress-bar{height:100%;border-radius:3px;transition:width .4s ease}.progress-label{font-size:11px;color:var(--muted);white-space:nowrap}.pain-trend{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--muted2)}.trend-pill{padding:2px 8px;border-radius:20px;font-size:11px;font-weight:500}.trend-pill.improving{background:var(--green-dim);color:var(--green)}.trend-pill.stable{background:var(--amber-dim);color:var(--amber)}.trend-pill.worsening{background:var(--red-dim);color:var(--red)}.trend-pill.unknown{background:#64748b26;color:var(--muted2)}.case-card-footer{padding:10px 18px 14px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px}.case-detail{padding:24px;max-width:760px}.detail-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:24px}.detail-color-accent{width:5px;border-radius:4px;align-self:stretch;min-height:48px;flex-shrink:0}.detail-title{font-family:Fraunces,serif;font-size:26px;font-weight:500;letter-spacing:-.5px}.detail-meta{font-size:13px;color:var(--muted);margin-top:4px}.detail-summary{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:24px;font-size:14px;color:var(--muted2);line-height:1.65;font-weight:300}.section-heading{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px}.exercises-list{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}.exercise-row{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:border-color .2s}.exercise-row.done{border-color:#2dd4bf4d}.exercise-row-header{padding:14px 16px;display:flex;align-items:center;gap:12px;cursor:pointer}.ex-checkbox{width:22px;height:22px;border-radius:6px;border:2px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.ex-checkbox.checked{background:var(--teal);border-color:var(--teal)}.ex-checkbox svg{display:none}.ex-checkbox.checked svg{display:block}.ex-name{font-size:14px;font-weight:500;flex:1}.ex-duration{font-size:12px;color:var(--teal);background:var(--teal-dim);padding:3px 9px;border-radius:20px}.ex-expand{color:var(--muted);font-size:18px;transition:transform .2s;margin-left:4px}.ex-expand.open{transform:rotate(180deg)}.exercise-detail{padding:12px 16px 14px 50px;font-size:13px;color:var(--muted2);line-height:1.6;font-weight:300;border-top:1px solid var(--border)}.exercise-detail .benefit{margin-top:8px;font-size:12px;color:var(--teal);font-style:italic}.session-complete-bar{background:linear-gradient(135deg,#2dd4bf1a,#34d3990d);border:1px solid rgba(45,212,191,.25);border-radius:12px;padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;gap:16px}.complete-icon{font-size:28px}.complete-text h3{font-size:15px;font-weight:500;color:var(--teal)}.complete-text p{font-size:13px;color:var(--muted2);margin-top:2px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:18px;padding:28px;max-width:440px;width:100%;animation:scaleIn .25s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal h2{font-family:Fraunces,serif;font-size:22px;font-weight:500;margin-bottom:6px}.modal p{font-size:14px;color:var(--muted2);line-height:1.5;margin-bottom:24px;font-weight:300}.pain-scale{display:flex;gap:6px;margin-bottom:8px}.pain-btn{flex:1;aspect-ratio:1;border-radius:10px;border:1px solid var(--border2);background:transparent;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted2);transition:all .15s;font-family:Geist,sans-serif}.pain-btn:hover{border-color:var(--border2);background:var(--surface2)}.pain-btn.selected{color:#000;border-color:transparent}.pain-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);margin-bottom:20px}.pain-notes{width:100%;background:var(--surface2);border:1px solid var(--border2);border-radius:10px;padding:10px 14px;color:var(--text);font-family:Geist,sans-serif;font-size:13px;resize:none;outline:none;height:72px;font-weight:300;margin-bottom:16px}.pain-notes::placeholder{color:var(--muted)}.modal-actions{display:flex;gap:8px;justify-content:flex-end}.progress-view{padding:24px}.progress-header{margin-bottom:24px}.progress-header h2{font-family:Fraunces,serif;font-size:22px;font-weight:500}.progress-header p{font-size:13px;color:var(--muted);margin-top:4px}.progress-cards{display:flex;flex-direction:column;gap:20px}.progress-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden}.progress-card-header{padding:18px 20px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}.progress-card-title{font-family:Fraunces,serif;font-size:17px;font-weight:500;flex:1}.progress-card-body{padding:18px 20px}.sparkline-wrap{margin-bottom:16px}.sparkline-label{font-size:11px;color:var(--muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.6px}.checkins-list{display:flex;flex-direction:column;gap:8px}.checkin-row{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface2);border-radius:10px;font-size:13px}.checkin-date{color:var(--muted2);width:72px;flex-shrink:0;font-size:12px}.checkin-exercises{flex:1;color:var(--muted2);font-size:12px}.pain-dot{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px;flex-shrink:0}.adaptation-block{background:#2dd4bf0d;border:1px solid rgba(45,212,191,.15);border-radius:12px;padding:14px 16px;margin-top:16px}.adaptation-block h4{font-size:13px;font-weight:600;color:var(--teal);margin-bottom:6px}.adaptation-block p{font-size:13px;color:var(--muted2);line-height:1.55;font-weight:300}.adaptation-changes{margin-top:10px;display:flex;flex-direction:column;gap:6px}.adaptation-change-item{display:flex;align-items:flex-start;gap:8px;font-size:12.5px;color:var(--muted2)}.change-badge{padding:1px 7px;border-radius:10px;font-size:10px;font-weight:600;flex-shrink:0;margin-top:1px}.change-badge.keep{background:#4ade801a;color:var(--green)}.change-badge.modify{background:var(--amber-dim);color:var(--amber)}.change-badge.remove{background:var(--red-dim);color:var(--red)}.change-badge.intensity_up{background:#6366f126;color:#a5b4fc}.change-badge.intensity_down{background:#fbbf241a;color:var(--amber)}.change-badge.new{background:var(--teal-dim);color:var(--teal)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center}.empty-icon{font-size:52px;margin-bottom:16px;opacity:.5}.empty h3{font-family:Fraunces,serif;font-size:20px;font-weight:500;color:var(--muted2)}.empty p{font-size:14px;color:var(--muted);margin-top:8px;max-width:320px;font-weight:300}canvas{border-radius:8px}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:500}.tag.mild{background:#4ade801a;color:var(--green)}.tag.moderate{background:var(--amber-dim);color:var(--amber)}.tag.severe{background:var(--red-dim);color:var(--red)}.divider{height:1px;background:var(--border);margin:16px 0}.frequency-badge{display:inline-flex;align-items:center;gap:5px;background:var(--surface2);border:1px solid var(--border2);color:var(--muted2);padding:4px 12px;border-radius:20px;font-size:12px;margin-bottom:16px}
