*{box-sizing:border-box}[data-theme=light],:root{--bg: #faf9f7;--bg-card: rgba(255, 255, 255, .75);--bg-card-solid: #fffefc;--bg-input: rgba(255, 255, 255, .9);--border: rgba(0, 0, 0, .06);--border-strong: rgba(0, 0, 0, .12);--text: #2d2a26;--text-muted: #6b6560;--accent: #5b8def;--accent-hover: #4a7ad9;--accent-soft: rgba(91, 141, 239, .12);--accent-soft-hover: rgba(91, 141, 239, .2);--shadow: 0 2px 12px rgba(0, 0, 0, .04);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08);--success: #22c55e;--error: #ef4444}[data-theme=dark]{--bg: #1a1b1e;--bg-card: rgba(36, 37, 41, .8);--bg-card-solid: #242529;--bg-input: rgba(36, 37, 41, .95);--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .15);--text: #f4f3f1;--text-muted: #a19d97;--accent: #6b9aff;--accent-hover: #8bb3ff;--accent-soft: rgba(107, 154, 255, .15);--accent-soft-hover: rgba(107, 154, 255, .25);--shadow: 0 2px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--success: #4ade80;--error: #f87171}body{margin:0;min-height:100vh;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);transition:background-color .3s ease,color .3s ease}#root{min-height:100vh}.app{max-width:720px;margin:0 auto;padding:1.5rem}.theme-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;cursor:pointer;font-size:.875rem;color:var(--text-muted);transition:all .2s ease;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.theme-toggle:hover{background:var(--accent-soft);color:var(--accent);border-color:var(--accent)}.theme-toggle span{font-size:1.1rem}.header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}.header-left{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.header h1{font-size:1.5rem;font-weight:700;color:var(--accent);margin:0}.header-user{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-muted)}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--border)}.loading,.error-card{text-align:center;padding:3rem 1.5rem}.loading{color:var(--text-muted);font-size:1rem}.error-card{background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--border);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.error-card .hint{color:var(--text-muted);font-size:.9rem;margin-top:1rem}.main{display:flex;flex-direction:column;gap:1.5rem}.card{background:var(--bg-card);border-radius:16px;box-shadow:var(--shadow);border:1px solid var(--border);padding:1.5rem;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:box-shadow .2s ease,border-color .2s ease}.card:hover{box-shadow:var(--shadow-lg)}.card h2{font-size:1.15rem;font-weight:600;margin:0 0 1rem;color:var(--text)}.card h3{font-size:.95rem;font-weight:600;margin:1rem 0 .5rem;color:var(--text)}.profile-card .room{color:var(--text-muted);font-size:.9rem;margin:.25rem 0 0}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.8rem;color:var(--text-muted)}.suggestions ul{margin:0;padding-left:1.25rem}.suggestions li{margin:.25rem 0;color:var(--text-muted)}.schedule-form{display:flex;flex-direction:column;gap:1rem}.schedule-form label{display:flex;flex-direction:column;gap:.35rem;font-size:.9rem;color:var(--text)}.schedule-form input,.schedule-form select,.schedule-form textarea{padding:.65rem .9rem;border:1px solid var(--border);border-radius:10px;font-size:1rem;background:var(--bg-input);color:var(--text);transition:border-color .2s ease,box-shadow .2s ease}.schedule-form input:focus,.schedule-form select:focus,.schedule-form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.schedule-form input::placeholder,.schedule-form textarea::placeholder{color:var(--text-muted)}.schedule-form button,.btn-primary{padding:.75rem 1.25rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;align-self:flex-start;transition:background .2s ease,transform .1s ease}.schedule-form button:hover:not(:disabled),.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.schedule-form button:disabled,.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.scheduled-list,.call-list{list-style:none;margin:0;padding:0}.scheduled-list li,.call-list li{padding:.9rem 0;border-bottom:1px solid var(--border)}.scheduled-list li:last-child,.call-list li:last-child{border-bottom:none}.scheduled-list .notes,.scheduled-list .recurrence,.call-list .call-summary{color:var(--text-muted);font-size:.9rem}.call-date{font-weight:600}.call-duration{font-size:.85rem;color:var(--accent);margin:.25rem 0}.call-summary{margin:.5rem 0 0;font-size:.9rem;color:var(--text-muted)}.muted{color:var(--text-muted);font-size:.9rem}.btn-confirm{margin-left:.75rem;padding:.4rem .9rem;font-size:.85rem;background:var(--accent);color:#fff;border:none;border-radius:8px;cursor:pointer;transition:background .2s ease}.btn-confirm:hover{background:var(--accent-hover)}.confirmed{margin-left:.5rem;color:var(--success);font-size:.9rem}.reaction-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.reaction-btn{padding:.65rem 1.1rem;font-size:.95rem;background:var(--accent-soft);border:1px solid var(--border);border-radius:10px;cursor:pointer;color:var(--text);transition:all .2s ease}.reaction-btn:hover:not(:disabled){background:var(--accent-soft-hover);border-color:var(--accent);transform:scale(1.02)}.reaction-btn:disabled{opacity:.6;cursor:not-allowed}.photo-upload-form{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.photo-caption{flex:1;min-width:120px;padding:.55rem .9rem;border:1px solid var(--border);border-radius:10px;background:var(--bg-input);color:var(--text)}.photo-caption::placeholder{color:var(--text-muted)}.photo-upload-label{padding:.55rem 1.1rem;background:var(--accent);color:#fff;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s ease}.photo-upload-label:hover{background:var(--accent-hover)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1rem}.photo-thumb{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;background:var(--bg-card-solid);border:1px solid var(--border)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-caption-text{position:absolute;bottom:0;left:0;right:0;padding:.35rem .6rem;font-size:.75rem;background:#0009;color:#fff}.wellness-list{list-style:none;margin:0;padding:0}.wellness-list li{padding:.6rem 0;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.wellness-date{font-weight:600;min-width:100px}.wellness-response{color:var(--accent)}.wellness-notes{color:var(--text-muted);font-size:.9rem}
