@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--primary-50:#f0f9ff;--primary-100:#e0f2fe;--primary-200:#bae6fd;--primary-300:#7dd3fc;--primary-400:#38bdf8;--primary-500:#0ea5e9;--primary-600:#0284c7;--primary-700:#0369a1;--primary-800:#075985;--primary-900:#0c4a6e;--accent-50:#f0fdf4;--accent-100:#dcfce7;--accent-200:#bbf7d0;--accent-400:#4ade80;--accent-500:#22c55e;--accent-600:#16a34a;--accent-700:#15803d;--warning-50:#fffbeb;--warning-100:#fef3c7;--warning-400:#fbbf24;--warning-500:#f59e0b;--warning-600:#d97706;--danger-50:#fff1f2;--danger-100:#ffe4e6;--danger-400:#fb7185;--danger-500:#f43f5e;--danger-600:#e11d48;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--gray-950:#020617;--bg-primary:#fff;--bg-secondary:#f4f8f9;--bg-card:#fff;--text-primary:var(--gray-800);--text-secondary:var(--gray-500);--text-muted:var(--gray-400);--border-color:#e2e8f099;--border-focus:var(--primary-400);--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--shadow-sm:0 4px 12px #0f172a05;--shadow-md:0 10px 30px #0f172a0a;--shadow-lg:0 20px 40px #0f172a0f;--shadow-xl:0 24px 48px #0f172a14;--shadow-glow:0 0 24px #0ea5e926;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:16px;line-height:1.6}body{background:var(--bg-secondary);color:var(--text-primary);min-height:100dvh}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:700;line-height:1.3}h1{letter-spacing:-.025em;font-size:2rem}h2{letter-spacing:-.02em;font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}p{color:var(--text-secondary)}a{color:var(--primary-600);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-700)}.container{max-width:1200px;padding:0 var(--space-6);margin:0 auto}.container-narrow{max-width:640px;padding:0 var(--space-6);margin:0 auto}.page-wrapper{flex-direction:column;min-height:100dvh;display:flex}.page-content{padding:var(--space-8) 0;flex:1}.card{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-8);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base), transform var(--transition-base);border:1px solid #fffc}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.card-header h2{font-size:1.25rem;font-weight:600}.card-header p{color:var(--text-muted);margin-top:var(--space-1);font-size:.875rem}.auth-wrapper{background:linear-gradient(135deg, var(--primary-900) 0%, var(--primary-700) 50%, var(--primary-800) 100%);min-height:100dvh;padding:var(--space-6);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.auth-wrapper:before{content:"";pointer-events:none;background:radial-gradient(circle,#3b82f626 0%,#0000 70%);border-radius:50%;width:600px;height:600px;position:absolute;top:-200px;right:-200px}.auth-wrapper:after{content:"";pointer-events:none;background:radial-gradient(circle,#10b9811a 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-150px;left:-100px}.auth-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-2xl);padding:var(--space-10);width:100%;max-width:460px;box-shadow:var(--shadow-xl), 0 0 60px #0000001a;z-index:1;background:#fffffff7;position:relative}.auth-logo{text-align:center;margin-bottom:var(--space-8)}.auth-logo-icon{background:linear-gradient(135deg, var(--primary-500), var(--primary-700));border-radius:var(--radius-lg);width:56px;height:56px;margin:0 auto var(--space-4);justify-content:center;align-items:center;display:flex;box-shadow:0 4px 12px #2563eb4d}.auth-logo-icon svg{color:#fff;width:28px;height:28px}.auth-logo h1{color:var(--gray-900);font-size:1.5rem;font-weight:700}.auth-logo p{color:var(--gray-500);margin-top:var(--space-1);font-size:.875rem}.form-group{margin-bottom:var(--space-5)}.form-label{color:var(--text-primary);margin-bottom:var(--space-2);font-size:.875rem;font-weight:500;display:block}.form-label .required{color:var(--danger-500);margin-left:2px}.form-input{width:100%;padding:var(--space-3) var(--space-4);color:var(--text-primary);background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;font-family:inherit;font-size:.9375rem}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f61f}.form-input::placeholder{color:var(--text-muted)}.form-input:disabled{background:var(--gray-100);cursor:not-allowed;opacity:.7}.form-input-error{border-color:var(--danger-500)}.form-input-error:focus{box-shadow:0 0 0 3px #ef44441f}.form-error{color:var(--danger-600);margin-top:var(--space-1);align-items:center;gap:var(--space-1);font-size:.8125rem;display:flex}.form-hint{color:var(--text-muted);margin-top:var(--space-1);font-size:.8125rem}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 8.825L.35 3.175l.7-.7L6 7.425l4.95-4.95.7.7z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}textarea.form-input{resize:vertical;min-height:100px}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-6);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-family:inherit;font-size:.9375rem;font-weight:500;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--primary-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-success{background:var(--accent-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-success:hover:not(:disabled){background:var(--accent-700);transform:translateY(-1px)}.btn-danger{background:var(--danger-600);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-700)}.btn-ghost{color:var(--text-secondary);padding:var(--space-2) var(--space-3);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--gray-100);color:var(--text-primary)}.btn-lg{padding:var(--space-4) var(--space-8);border-radius:var(--radius-full);font-size:1rem}.btn-sm{padding:var(--space-2) var(--space-4);font-size:.8125rem}.btn-full{width:100%}.btn-icon{padding:var(--space-2);border-radius:var(--radius-full)}.nav{z-index:50;-webkit-backdrop-filter:blur(16px)saturate(180%);background:#ffffffd9;border-bottom:1px solid #ffffff4d;position:sticky;top:0;box-shadow:0 4px 24px #0f172a08}.nav:before{content:"";background:var(--primary-500);height:2px;position:absolute;top:0;left:0;right:0}.nav-inner{max-width:1200px;padding:0 var(--space-4);align-items:center;gap:var(--space-4);height:72px;margin:0 auto;display:flex}.nav-brand{align-items:center;gap:var(--space-3);color:var(--gray-900);flex-shrink:0;text-decoration:none;display:flex}.nav-brand-icon{border-radius:var(--radius-md);background:var(--primary-50);width:36px;height:36px;color:var(--primary-600);border:1px solid var(--primary-100);justify-content:center;align-items:center;display:flex}.nav-brand-text{color:var(--gray-900);font-size:1rem;font-weight:700;line-height:1.2}.nav-brand-sub{color:var(--gray-400);font-size:.7rem;font-weight:400}.nav-links{gap:var(--space-1);flex:1;min-width:0;margin:0;padding:0;list-style:none;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--gray-500);white-space:nowrap;transition:all var(--transition-fast);align-items:center;gap:6px;padding:8px 12px;font-size:.8rem;font-weight:500;text-decoration:none;display:inline-flex;position:relative}.nav-link svg{opacity:.6;flex-shrink:0}.nav-link:hover{color:var(--gray-700);background:var(--gray-50)}.nav-link:hover svg{opacity:.9}.nav-link.active{color:var(--primary-700);background:var(--primary-50);font-weight:600}.nav-link.active svg{opacity:1;color:var(--primary-600)}.nav-link.active:after{content:"";background:var(--primary-500);border-radius:50%;width:4px;height:4px;position:absolute;bottom:4px;left:50%;transform:translate(-50%)}.nav-user{align-items:center;gap:var(--space-3);flex-shrink:0;margin-left:auto;display:flex}.nav-user-info{text-align:right}.nav-user-name{color:var(--gray-800);font-size:.85rem;font-weight:600;line-height:1.3}.nav-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.75rem;font-weight:700;display:flex}.nav-avatar--sm{width:30px;height:30px;font-size:.65rem}.nav-avatar--provider{background:var(--accent-100);color:var(--accent-700);border:2px solid var(--accent-200)}.nav-avatar--patient{background:var(--primary-100);color:var(--primary-700);border:2px solid var(--primary-200)}.nav-role-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:4px;padding:1px 6px;font-size:.65rem;font-weight:600;display:inline-flex}.nav-role-badge--provider{background:var(--accent-100);color:var(--accent-700)}.nav-role-badge--patient{background:var(--primary-100);color:var(--primary-700)}.nav-role-badge-dot{border-radius:50%;width:5px;height:5px;display:inline-block}.nav-role-badge--provider .nav-role-badge-dot{background:var(--accent-500)}.nav-role-badge--patient .nav-role-badge-dot{background:var(--primary-500)}.nav-divider{background:var(--gray-200);width:1px;height:28px;margin:0 var(--space-1)}.nav-signout{color:var(--gray-400);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:1px solid #0000;align-items:center;gap:4px;padding:6px 12px;font-size:.75rem;font-weight:500;display:inline-flex}.nav-signout svg{width:14px;height:14px}.nav-signout:hover{color:var(--danger-600);background:var(--danger-50);border-color:var(--danger-100)}.nav-mobile-controls{align-items:center;gap:var(--space-2);margin-left:auto;display:none}.nav-hamburger{border:1px solid var(--gray-200);border-radius:var(--radius-md);cursor:pointer;width:40px;height:40px;color:var(--gray-600);transition:all var(--transition-fast);background:0 0;justify-content:center;align-items:center;display:flex}.nav-hamburger:hover{background:var(--gray-50);color:var(--gray-900)}.nav-mobile-menu{border-bottom:1px solid var(--gray-200);z-index:999;padding:var(--space-4);background:#fff;animation:.2s ease-out slideDown;position:fixed;top:67px;left:0;right:0;box-shadow:0 8px 32px #00000014}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.nav-mobile-user{align-items:center;gap:var(--space-3);padding-bottom:var(--space-4);border-bottom:1px solid var(--gray-100);margin-bottom:var(--space-3);display:flex}.nav-mobile-links{margin:0;padding:0;list-style:none}.nav-mobile-link{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);color:var(--gray-600);transition:all var(--transition-fast);font-size:.9rem;font-weight:500;text-decoration:none;display:flex}.nav-mobile-link:hover{background:var(--gray-50);color:var(--gray-900)}.nav-mobile-link.active{background:var(--primary-50);color:var(--primary-700);font-weight:600}.nav-mobile-link svg{flex-shrink:0}.nav-mobile-footer{padding-top:var(--space-3);border-top:1px solid var(--gray-100);margin-top:var(--space-3)}.nav-signout--mobile{width:100%;padding:var(--space-3);border:1px solid var(--danger-100);color:var(--danger-600);border-radius:var(--radius-md);justify-content:center;font-size:.85rem}@media (max-width:900px){.nav-links--desktop,.nav-user--desktop{display:none!important}.nav-mobile-controls{display:flex}}@media (min-width:901px){.nav-mobile-controls,.nav-mobile-menu{display:none!important}}.badge{padding:2px var(--space-3);border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;font-size:.75rem;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-100);color:var(--primary-700)}.badge-success{background:var(--accent-100);color:var(--accent-700)}.badge-warning{background:var(--warning-100);color:var(--warning-600)}.badge-danger{background:var(--danger-100);color:var(--danger-600)}.badge-neutral{background:var(--gray-100);color:var(--gray-600)}.status-dot{border-radius:50%;width:8px;height:8px;display:inline-block}.status-dot-active{background:var(--accent-500);animation:2s infinite pulse;box-shadow:0 0 0 3px #10b98133}.status-dot-inactive{background:var(--gray-300)}.status-dot-warning{background:var(--warning-500)}.status-dot-danger{background:var(--danger-500)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.alert{padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);align-items:flex-start;gap:var(--space-3);font-size:.875rem;line-height:1.5;display:flex}.alert-info{background:var(--primary-50);border:1px solid var(--primary-200);color:var(--primary-800)}.alert-success{background:var(--accent-50);border:1px solid var(--accent-200);color:var(--accent-700)}.alert-warning{background:var(--warning-50);border:1px solid var(--warning-100);color:var(--warning-600)}.alert-danger{background:var(--danger-50);border:1px solid var(--danger-100);color:var(--danger-600)}.hipaa-banner{background:var(--primary-50);color:var(--primary-800);padding:var(--space-2) var(--space-6);text-align:center;justify-content:center;align-items:center;gap:var(--space-2);border-bottom:1px solid var(--primary-100);font-size:.75rem;font-weight:500;display:flex}.hipaa-banner svg{width:14px;height:14px}.waiting-room{text-align:center;justify-content:center;align-items:center;min-height:80dvh;display:flex}.waiting-room-card{max-width:500px;padding:var(--space-12)}.waiting-room-spinner{border:4px solid var(--primary-100);border-top-color:var(--primary-500);width:80px;height:80px;margin:0 auto var(--space-8);border-radius:50%;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.table-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:var(--gray-50)}th{padding:var(--space-3) var(--space-4);text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);font-size:.75rem;font-weight:600}td{padding:var(--space-4);border-bottom:1px solid var(--border-color);font-size:.875rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--gray-50)}.dashboard-grid{gap:var(--space-6);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.stat-card{padding:var(--space-8);background:linear-gradient(#fff 0%,#ffffff80 100%)}.stat-card-label{color:var(--primary-600);text-transform:uppercase;letter-spacing:.05em;font-size:.8125rem;font-weight:600}.stat-card-value{color:var(--primary-900);margin-top:var(--space-2);letter-spacing:-.04em;font-size:2.5rem;font-weight:800;line-height:1}.stat-card-meta{color:var(--text-muted);margin-top:var(--space-2);font-size:.8125rem}.meet-join-btn{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-8);color:#fff;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);background:linear-gradient(135deg,#1a73e8,#1557b0);border:none;font-size:1rem;font-weight:600;text-decoration:none;display:inline-flex;box-shadow:0 4px 14px #1a73e859}.meet-join-btn:hover{color:#fff;background:linear-gradient(135deg,#1557b0,#0d47a1);transform:translateY(-2px);box-shadow:0 6px 20px #1a73e873}.meet-join-btn svg{width:24px;height:24px}.consent-document{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-8);max-height:400px;margin-bottom:var(--space-6);font-size:.875rem;line-height:1.8;overflow-y:auto}.consent-document h3{margin-top:var(--space-6);margin-bottom:var(--space-3)}.consent-document ul{padding-left:var(--space-6);margin-bottom:var(--space-4)}.consent-checkbox{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);background:var(--primary-50);border:1px solid var(--primary-200);border-radius:var(--radius-md);cursor:pointer;display:flex}.consent-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary-600);margin-top:2px}.landing-hero{text-align:center;z-index:1;max-width:600px;position:relative}.landing-hero h1{color:#fff;letter-spacing:-.03em;font-size:2.25rem;line-height:1.2}.landing-hero .subtitle{color:#ffffffb3;margin-top:var(--space-2);font-size:1.125rem}.landing-hero .description{color:#fff9;max-width:480px;margin:0 auto;font-size:.9375rem;line-height:1.7}.landing-cards{gap:var(--space-5);z-index:1;grid-template-columns:1fr 1fr;width:100%;max-width:560px;display:grid;position:relative}.landing-card{text-align:center;padding:var(--space-8) var(--space-6);cursor:pointer;transition:all var(--transition-base);flex-direction:column;align-self:stretch;align-items:center;text-decoration:none;display:flex}.landing-card--patient{border:1px solid #3b82f633}.landing-card--patient:hover{box-shadow:var(--shadow-lg), 0 0 24px #3b82f614;border-color:#3b82f673;transform:translateY(-3px)}.landing-card--provider{border:1px solid #10b98133}.landing-card--provider:hover{box-shadow:var(--shadow-lg), 0 0 24px #10b98114;border-color:#10b98173;transform:translateY(-3px)}.landing-card:active{transform:translateY(0)}.landing-card-icon{border-radius:var(--radius-lg);width:48px;height:48px;margin-bottom:var(--space-4);flex-shrink:0;justify-content:center;align-items:center;display:flex}.landing-card-icon--blue{background:linear-gradient(135deg, var(--primary-100), var(--primary-200))}.landing-card-icon--green{background:linear-gradient(135deg, var(--accent-100), var(--accent-200))}.landing-card h3{margin-bottom:var(--space-1);font-size:1rem}.landing-card .landing-card-desc{color:var(--text-muted);margin-bottom:var(--space-4);align-items:center;min-height:2.6em;font-size:.8125rem;display:flex}.landing-card-features{border-top:1px solid var(--border-color);width:100%;padding:0;padding-top:var(--space-3);margin:0;list-style:none}.landing-card-features li{color:var(--text-secondary);padding:var(--space-1) 0;align-items:center;gap:var(--space-2);font-size:.75rem;display:flex}.landing-card-features li svg{flex-shrink:0}.landing-footer{text-align:center;z-index:1;align-items:center;gap:var(--space-3);flex-direction:column;display:flex;position:relative}.landing-badges{align-items:center;gap:var(--space-4);color:#ffffff80;font-size:.75rem;display:flex}.landing-badges span{align-items:center;gap:var(--space-1);display:flex}.landing-copyright{color:#ffffff59;font-size:.6875rem}.landing-copyright a{color:#ffffff73;margin-left:var(--space-2)}@media (max-width:768px){h1{font-size:1.5rem}h2{font-size:1.25rem}.auth-card{padding:var(--space-6)}.card{padding:var(--space-5)}.dashboard-grid{grid-template-columns:1fr}.nav-links{display:none}.landing-cards{grid-template-columns:1fr}.landing-badges{flex-wrap:wrap;justify-content:center}}
