@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Inter:wght@400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{font-family:Outfit,Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f0f4f8;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;--clr-accent: #2563eb;--clr-green: #059669;--clr-teal: #0891b2;--clr-red: #dc2626;--clr-purple: #7c3aed;--clr-yellow: #d97706;--clr-text: #0f172a;--clr-text-muted: #64748b;--clr-bg: #f0f4f8;--clr-card: #ffffff;--clr-border: rgba(148, 163, 184, .2);--card-shadow: 0 2px 12px rgba(0, 0, 0, .07), 0 1px 3px rgba(0,0,0,.04)}body{margin:0;min-height:100vh;min-height:100dvh;overflow:hidden}#root{min-height:100vh;min-height:100dvh}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:16px;background:linear-gradient(135deg,#e0e7ff,#f0f4f8,#dbeafe)}.login-card{display:flex;flex-direction:column;align-items:center;width:100%;max-width:380px;padding:40px 32px;background:#fff;border:1px solid var(--clr-border);border-radius:24px;box-shadow:0 8px 40px #00000014}.login-logo{width:72px;height:72px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f0fdf4;border:1px solid rgba(5,150,105,.15);margin-bottom:16px}.login-title{font-size:1.6rem;font-weight:700;color:var(--clr-text);margin:0}.login-subtitle{font-size:.85rem;color:var(--clr-text-muted);margin:4px 0 28px}.login-fields{display:flex;flex-direction:column;gap:16px;width:100%;margin-bottom:20px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:.75rem;font-weight:600;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.06em}.login-field input{width:100%;padding:12px 14px;border:1px solid var(--clr-border);border-radius:12px;background:#f8fafc;color:var(--clr-text);font-size:1rem;font-family:Outfit,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s}.login-field input::placeholder{color:#94a3b8}.login-field input:focus{border-color:var(--clr-green);box-shadow:0 0 0 3px #0596691a;background:#fff}.login-error{width:100%;margin-bottom:12px;padding:10px 14px;border-radius:10px;background:#dc26260f;border:1px solid rgba(220,38,38,.15);color:var(--clr-red);font-size:.85rem;text-align:center}.login-btn{display:flex;align-items:center;justify-content:center;width:100%;padding:14px;border:none;border-radius:14px;background:var(--clr-green);color:#fff;font-size:1rem;font-weight:600;font-family:Outfit,sans-serif;cursor:pointer;min-height:52px;box-shadow:0 4px 16px #05966933;transition:transform .15s,box-shadow .2s}.login-btn:hover:not(:disabled){transform:translateY(-1px)}.login-btn:disabled{opacity:.4;cursor:default}.login-spinner{display:inline-block;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.dashboard{min-height:100vh;background:var(--clr-bg);display:flex;flex-direction:column}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--clr-card);border-bottom:1px solid var(--clr-border);box-shadow:0 1px 3px #0000000a}.dash-header-left{display:flex;align-items:center;gap:12px}.dash-title{font-size:1.2rem;font-weight:700;color:var(--clr-text);margin:0;line-height:1.2}.dash-subtitle{font-size:.75rem;color:var(--clr-text-muted);margin:0}.dash-header-right{display:flex;align-items:center;gap:16px}.dash-user{display:flex;align-items:center;gap:10px}.dash-user-avatar{width:36px;height:36px;border-radius:50%;background:#f0fdf4;color:var(--clr-green);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem;border:1px solid rgba(5,150,105,.15)}.dash-user-name{font-size:.85rem;font-weight:600;color:var(--clr-text)}.dash-user-role{font-size:.7rem;color:var(--clr-text-muted);text-transform:capitalize}.dash-logout{padding:8px 16px;border:1px solid var(--clr-border);border-radius:10px;background:#fff;color:var(--clr-text-muted);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:Outfit,sans-serif}.dash-logout:hover{background:#f1f5f9;color:var(--clr-text)}.dash-body{flex:1;padding:24px;max-width:960px;margin:0 auto;width:100%;overflow-y:auto}.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dash-section-header h2{font-size:1.1rem;font-weight:700;color:var(--clr-text);margin:0}.dash-refresh{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--clr-border);border-radius:10px;background:#fff;color:var(--clr-text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:Outfit,sans-serif}.dash-refresh:hover{background:#f1f5f9;color:var(--clr-text)}.dash-empty,.dash-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--clr-text-muted);text-align:center}.dash-empty h3{margin:16px 0 4px;font-size:1rem;color:var(--clr-text)}.dash-empty p{font-size:.85rem}.dash-spinner{width:32px;height:32px;border:3px solid var(--clr-border);border-top-color:var(--clr-green);border-radius:50%;animation:spin .7s linear infinite;margin-bottom:12px}.dash-rooms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.dash-room-card{background:var(--clr-card);border:1px solid var(--clr-border);border-radius:16px;padding:20px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:12px;transition:box-shadow .2s}.dash-room-card:hover{box-shadow:0 4px 20px #00000014}.dash-room-waiting{border-left:4px solid #f59e0b}.dash-room-active{border-left:4px solid var(--clr-green)}.dash-room-empty,.dash-room-offline{border-left:4px solid #94a3b8;opacity:.75}.dash-patient-count{font-size:.8rem;color:var(--clr-text-muted);margin-right:auto;margin-left:12px;padding:4px 12px;background:#f1f5f9;border-radius:100px}.dash-room-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.dash-patient-info{display:flex;align-items:center;gap:10px;flex:1}.dash-patient-avatar{width:40px;height:40px;border-radius:50%;background:#e0e7ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.dash-room-name{font-size:1rem;font-weight:700;color:var(--clr-text)}.dash-patient-meta{font-size:.75rem;color:var(--clr-text-muted);margin-top:1px}.dash-room-details{display:flex;flex-wrap:wrap;gap:12px}.dash-detail{display:flex;align-items:center;gap:4px;font-size:.8rem;color:var(--clr-text-muted)}.dash-room-badge{font-size:.65rem;font-weight:700;padding:3px 10px;border-radius:100px;text-transform:uppercase;letter-spacing:.04em}.dash-badge-waiting{background:#fef3c7;color:#92400e}.dash-badge-active{background:#d1fae5;color:#065f46}.dash-badge-empty{background:#f1f5f9;color:#64748b}.dash-room-meta{display:flex;gap:16px;font-size:.8rem;color:var(--clr-text-muted)}.dash-room-participants{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:#f8fafc;border-radius:10px;border:1px solid var(--clr-border)}.dash-participant{display:flex;align-items:center;gap:10px}.dash-p-avatar{width:30px;height:30px;border-radius:50%;background:#e0e7ff;color:#4338ca;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.75rem;flex-shrink:0}.dash-p-info{flex:1}.dash-p-name{font-size:.85rem;font-weight:600;color:var(--clr-text)}.dash-p-meta{font-size:.7rem;color:var(--clr-text-muted)}.dash-p-live{font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:100px;background:#fef2f2;color:var(--clr-red);letter-spacing:.06em}.dash-join-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border:none;border-radius:12px;background:var(--clr-green);color:#fff;font-size:.9rem;font-weight:600;font-family:Outfit,sans-serif;cursor:pointer;transition:transform .15s,box-shadow .2s;box-shadow:0 2px 8px #05966933}.dash-join-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px #0596694d}.dash-join-urgent{background:#f59e0b;box-shadow:0 2px 8px #f59e0b4d;animation:dash-pulse 2s ease-in-out infinite}.dash-join-urgent:hover{box-shadow:0 4px 16px #f59e0b66}@keyframes dash-pulse{0%,to{box-shadow:0 2px 8px #f59e0b4d}50%{box-shadow:0 2px 16px #f59e0b80}}.dash-badge-offline{background:#f1f5f9;color:#94a3b8}@media(max-width:600px){.dash-header{padding:12px 16px}.dash-body{padding:16px}.dash-rooms-grid{grid-template-columns:1fr}.dash-user-name,.dash-user-role{display:none}}.join-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:16px;background:linear-gradient(135deg,#e0e7ff,#f0f4f8,#dbeafe)}.join-card{display:flex;flex-direction:column;align-items:center;width:100%;max-width:400px;padding:40px 32px;background:#fff;border:1px solid var(--clr-border);border-radius:24px;box-shadow:0 8px 40px #00000014}.join-logo{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:16px;border-radius:50%;background:#05966914;border:1px solid rgba(5,150,105,.15)}.join-logo svg{stroke:var(--clr-green)}.join-title{margin:0;font-size:1.75rem;font-weight:700;color:var(--clr-text);letter-spacing:-.02em}.join-subtitle{margin:4px 0 28px;font-size:.85rem;color:var(--clr-text-muted)}.join-fields{display:flex;flex-direction:column;gap:16px;width:100%;margin-bottom:24px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:.75rem;font-weight:600;color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:.06em}.field input{width:100%;padding:14px 16px;border:1px solid var(--clr-border);border-radius:12px;background:#f8fafc;color:var(--clr-text);font-size:1rem;font-family:Outfit,sans-serif;outline:none;transition:border-color .2s,box-shadow .2s}.field input::placeholder{color:#94a3b8}.field input:focus{border-color:var(--clr-green);box-shadow:0 0 0 3px #0596691a;background:#fff}.join-error{width:100%;margin-bottom:12px;padding:10px 14px;border-radius:10px;background:#dc26260f;border:1px solid rgba(220,38,38,.15);color:var(--clr-red);font-size:.85rem;text-align:center}.join-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:none;border-radius:14px;background:var(--clr-green);color:#fff;font-size:1rem;font-weight:600;font-family:Outfit,sans-serif;cursor:pointer;transition:transform .15s,box-shadow .2s;min-height:52px;box-shadow:0 4px 16px #05966933}.join-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #0596694d}.join-btn:active:not(:disabled){transform:scale(.98)}.join-btn:disabled{opacity:.4;cursor:not-allowed}.join-spinner{display:inline-block;width:20px;height:20px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.join-spinner.large{width:36px;height:36px;border-width:3px;border-color:#05966933;border-top-color:var(--clr-green)}@keyframes spin{to{transform:rotate(360deg)}}
