body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;margin:0;padding:0}:root{--primary-color:#2563eb;--primary-hover:#1d4ed8;--secondary-color:#0ea5e9;--accent-color:#06b6d4;--mint:#22d3ee;--lavender:#a855f7;--success-color:#10b981;--bg-gradient-start:#0b1224;--bg-gradient-end:#0c1e38;--card-bg:#ffffffe6;--glass-surface:#ffffff0f;--glass-strong:#ffffff1f;--text-primary:#1e293b;--text-secondary:#475569;--text-inverse:#e2e8f0;--border-color:#94a3b84d;--shadow-color:#0000001a}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Space Grotesk,Inter,SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;scrollbar-width:none}body::-webkit-scrollbar{display:none}html{scrollbar-width:none}html::-webkit-scrollbar{display:none}input,select,textarea{font-size:16px}.App{background:radial-gradient(circle at 18% 22%,#22d3ee29,#0000 30%),radial-gradient(circle at 80% 8%,#6366f133,#0000 32%),linear-gradient(135deg,#0b1224,#0c1e38);background:radial-gradient(circle at 18% 22%,#22d3ee29,#0000 30%),radial-gradient(circle at 80% 8%,#6366f133,#0000 32%),linear-gradient(135deg,var(--bg-gradient-start),var(--bg-gradient-end));min-height:100vh;overflow:hidden;position:relative}@keyframes cursor-pulse{0%,to{opacity:.7;transform:translate(-50%,-50%) scale(1)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.2)}}.floating-objects{height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%;z-index:0}.floating-tooth{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));opacity:.15;position:absolute}.floating-tooth svg{fill:#fff;stroke:#d1d5db;stroke-width:1}.tooth-1{animation:tooth-float-1 25s ease-in-out infinite;height:80px;left:5%;top:10%;width:80px}.tooth-2{animation:tooth-float-2 30s ease-in-out infinite;height:70px;right:10%;top:60%;width:70px}.tooth-3{animation:tooth-float-3 20s ease-in-out infinite;height:60px;left:15%;top:80%;width:60px}.tooth-4{animation:tooth-float-4 28s ease-in-out infinite;height:85px;right:5%;top:30%;width:85px}.tooth-5{animation:tooth-float-5 22s ease-in-out infinite;height:75px;left:50%;top:50%;width:75px}.tooth-6{animation:tooth-float-6 35s ease-in-out infinite;height:65px;right:20%;top:20%;width:65px}.tooth-7{animation:tooth-float-1 40s ease-in-out infinite reverse;bottom:15%;height:70px;right:30%;width:70px}.tooth-8{animation:tooth-float-2 32s ease-in-out infinite;height:60px;left:60%;top:70%;width:60px}.tooth-9{animation:tooth-float-3 30s ease-in-out infinite reverse;height:80px;left:10%;top:40%;width:80px}.tooth-10{animation:tooth-float-4 26s ease-in-out infinite;bottom:25%;height:65px;right:15%;width:65px}.tooth-11{animation:tooth-float-5 38s ease-in-out infinite;height:75px;left:35%;top:15%;width:75px}.tooth-12{animation:tooth-float-6 34s ease-in-out infinite reverse;bottom:20%;height:70px;left:25%;width:70px}@keyframes tooth-float-1{0%,to{transform:translate(0)}50%{transform:translate(20px,-30px)}}@keyframes tooth-float-2{0%,to{transform:translate(0)}50%{transform:translate(-25px,35px)}}@keyframes tooth-float-3{0%,to{transform:translate(0)}50%{transform:translate(30px,25px)}}@keyframes tooth-float-4{0%,to{transform:translate(0)}50%{transform:translate(-20px,-30px)}}@keyframes tooth-float-5{0%,to{transform:translate(0)}50%{transform:translate(25px,-20px)}}@keyframes tooth-float-6{0%,to{transform:translate(0)}50%{transform:translate(-30px,20px)}}.container{display:flex;flex-direction:column;margin:0 auto;min-height:100vh;padding:2rem;position:relative;width:100%;z-index:1}.auth-page-container{align-items:center;justify-content:center}.app-page-container{align-items:stretch;justify-content:flex-start;max-width:900px}.auth-wrapper{margin:0 auto;max-width:1400px;padding:0 1.25rem 2.5rem;width:100%}.auth-back-row{display:flex;justify-content:flex-start;margin-bottom:1rem}.auth-back-button{align-items:center;background:linear-gradient(135deg,#ffffff1f,#ffffff14);border:1px solid #ffffff59;border-radius:999px;box-shadow:0 8px 20px #ffffff1f;color:#fff;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;letter-spacing:.01em;padding:.65rem 1rem;transition:all .25s ease}.auth-back-button:hover{background:linear-gradient(135deg,#ffffff2e,#ffffff1f);border-color:#ffffff73;box-shadow:0 10px 24px #ffffff2e;transform:translateY(-1px)}.auth-back-icon{font-size:1.05rem;line-height:1}.auth-container{animation:fadeInUp .6s ease-out;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(135deg,#ffffff0a,#ffffff05);border:1px solid #ffffff1f;border-radius:28px;box-shadow:0 20px 60px #00000059;display:grid;grid-template-columns:1.05fr 1fr;margin:0 auto;max-width:1180px;min-height:640px;min-width:0;width:min(1180px,96vw)}.auth-container,.auth-left{overflow:hidden;position:relative}.auth-left{align-items:stretch;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);background:radial-gradient(circle at 20% 20%,#22d3ee29,#0000 42%),radial-gradient(circle at 70% 80%,#4f46e526,#0000 45%),linear-gradient(180deg,#0f172ad9,#172554e6);border-right:1px solid #ffffff1a;display:flex;justify-content:center;padding:3rem 2.75rem}.auth-glow{background:radial-gradient(circle at 30% 20%,#6366f12e,#0000 45%),radial-gradient(circle at 82% 60%,#0ea5e924,#0000 32%);filter:blur(24px);inset:0;position:absolute;z-index:0}.auth-left-content{display:flex;flex-direction:column;gap:1.5rem;max-width:520px;position:relative;z-index:1}.auth-logo-card{align-items:center;background:#ffffff0f;border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 20px 60px #00000040;display:flex;gap:1rem;padding:.9rem 1rem}.auth-logo-mark{align-items:center;background:radial-gradient(circle at 30% 30%,#6366f13d,#0ea5e92e);border-radius:16px;box-shadow:0 12px 30px #00000040;display:flex;height:88px;justify-content:center;width:88px}.auth-logo-mark svg{height:auto;width:68px}.auth-logo-eyebrow{color:#ffffffb3;font-size:.7rem;letter-spacing:.28em;margin:0 0 .15rem;text-transform:uppercase}.auth-logo-title{color:#fff;font-size:1.1rem;font-weight:700;margin:0}.auth-logo-copy{color:#ffffffb8;font-size:.9rem;line-height:1.5;margin:.25rem 0 0}.auth-left-title{color:#fff;font-size:clamp(2rem,3vw,2.4rem);line-height:1.2;margin:0}.auth-left-subtitle{color:#ffffffc7;font-size:1rem;line-height:1.65;margin:0}.auth-pill-row{display:flex;flex-wrap:wrap;gap:.65rem}.auth-pill{align-items:center;background:#ffffff14;border:1px solid #ffffff29;border-radius:999px;box-shadow:0 12px 26px #00000026;color:#e2e8f0;display:inline-flex;font-size:.85rem;gap:.4rem;padding:.45rem .8rem}.auth-metric-grid{grid-gap:.9rem;display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-top:.25rem}.auth-metric{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:14px;box-shadow:0 18px 36px #00000038;color:#e2e8f0;display:flex;flex-direction:column;gap:.2rem;padding:.85rem .95rem}.metric-value{font-size:1.4rem;font-weight:700}.metric-label{color:#ffffffb3;font-size:.9rem}.auth-right{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#0c1220a6;display:flex;flex-direction:column;justify-content:center;padding:2.5rem}.auth-card{background:#ffffff0d;border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 16px 40px #0000003d;padding:2rem}.auth-tabs{background:#ffffff0f;border:1px solid #ffffff24;border-radius:999px;display:inline-flex;gap:.25rem;margin-bottom:1.5rem;padding:.25rem}.auth-tab{background:#0000;border:none;border-radius:999px;color:#cbd5e1;cursor:pointer;font-size:.95rem;font-weight:700;padding:.65rem 1.2rem;transition:all .2s ease}.auth-tab.is-active{background:linear-gradient(135deg,#4f46e5e6,#0ea5e9e6);box-shadow:0 10px 30px #4f46e559;color:#fff}.auth-header{margin-bottom:1.5rem}.auth-title{color:#e2e8f0;font-size:1.85rem;font-weight:700;margin:0 0 .5rem}.auth-subtitle{color:#cbd5e1;font-size:1rem;margin:0}.auth-label{color:#94a3b8;font-size:.8rem;letter-spacing:.08em;margin:0 0 .5rem;text-transform:uppercase}.auth-mode-toggle{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(2,1fr);margin-bottom:1.5rem}.mode-chip{background:#ffffff0a;background-clip:padding-box;border:1px solid #ffffff29;border-radius:12px;color:#e2e8f0;cursor:pointer;font-weight:700;padding:.75rem .8rem;transition:all .2s ease}.mode-chip.is-active{background:linear-gradient(135deg,#22d3eed9,#4f46e5e6);background-clip:initial;border:none;box-shadow:0 10px 24px #4f46e559,0 0 0 1px #ffffff0f}.auth-form{gap:1.5rem}.auth-form,.form-group{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:#e2e8f0!important;font-size:.875rem;font-weight:600}.form-group input{background:#ffffff0f;border:1px solid #fff3;border-radius:14px;box-shadow:0 10px 26px #00000026;color:#e2e8f0;cursor:text;font-size:16px;padding:.875rem 1rem;transition:all .3s ease}.form-group input:focus{border-color:#4f46e5cc;box-shadow:0 0 0 3px #4f46e526;outline:none}.form-input-wrapper{align-items:center;display:flex;position:relative}.form-input-wrapper input{padding-right:3rem;width:100%}.input-visibility-toggle{align-items:center;background:#fffc;border:1px solid #0000;border-radius:999px;box-shadow:0 6px 16px #0000000f;color:#475569;color:var(--text-secondary);cursor:pointer;display:inline-flex;justify-content:center;padding:.35rem;position:absolute;right:.75rem;top:50%;transform:translateY(-50%);transition:all .2s ease}.input-visibility-toggle:hover{background:#2563eb14;border-color:#2563eb33;color:#2563eb;color:var(--primary-color)}.input-visibility-toggle.is-active{background:#2563eb1f;border-color:#2563eb40;color:#2563eb;color:var(--primary-color)}.form-group input::placeholder{color:#e2e8f0;opacity:.5}.auth-button{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:14px;box-shadow:0 10px 30px #14b8a659;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:.5rem;padding:1rem 2rem;transition:all .3s ease}.auth-button:hover{box-shadow:0 12px 28px #14b8a673;transform:translateY(-2px)}.auth-button:active{transform:translateY(0)}.auth-helper-links{display:flex;justify-content:flex-end;margin-top:.35rem}.auth-helper-links a{color:#a5b4fc;font-size:.9rem;font-weight:600;text-decoration:none;transition:opacity .2s ease}.auth-helper-links a:hover{opacity:.85}.password-hints{background:#ffffff0d;border:1px solid #ffffff1f;border-left:4px solid #667eea;border-radius:10px;margin-bottom:12px;padding:12px 14px}.password-hints-title{color:#e2e8f0;font-size:13px;font-weight:700;margin:0 0 8px}.password-hints-list{grid-gap:6px;color:#cbd5e1;display:grid;font-size:13px;gap:6px;list-style:none;margin:0;padding:0}.password-hints-list li.is-valid{color:#10b981;font-weight:700}.auth-error{background:#e53e3e1f;border:1px solid #e53e3e4d;border-radius:10px;color:#fecdd3;font-size:.9rem;margin:0 0 .5rem;padding:.75rem}.auth-toggle{border-top:1px solid #ffffff1f;margin-top:1.5rem;padding-top:1.5rem;text-align:center}.auth-toggle p{color:#cbd5e1;font-size:.95rem;margin:0}.auth-toggle button{background:none;border:none;color:#a5b4fc;cursor:pointer;font-size:.95rem;font-weight:700;padding:0;text-decoration:underline}.auth-toggle button:hover{color:#cbd5e1}.auth-legal-links{color:#cbd5e1;gap:.5rem;margin-top:1.25rem}.auth-legal-links .legal-link{background:none;border:none;color:inherit;cursor:pointer;font-weight:600;padding:0;transition:color .2s ease}.auth-legal-links .legal-link:hover{color:#a5b4fc}.auth-legal-links .legal-separator{color:#e2e8f0b3}@media (max-width:1100px){.auth-container{grid-template-columns:1fr;min-height:auto}.auth-left{border-bottom:1px solid #ffffff1a;border-right:none;padding:2.25rem 2rem}.auth-right{padding:1.75rem}.auth-card{padding:1.5rem}.auth-mode-toggle{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (max-width:720px){.auth-wrapper{padding:0 1rem 2rem}.auth-left-content{gap:1.25rem}.auth-left-title{font-size:1.9rem}.auth-logo-card{align-items:flex-start;flex-direction:column}.auth-pill-row{gap:.45rem}.auth-card,.auth-right{padding:1.25rem}.auth-tabs{justify-content:space-between;width:100%}.auth-tab{flex:1 1;text-align:center}.auth-mode-toggle{grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.auth-button{width:100%}}.toggle-link{background:none;border:none;color:#2563eb;color:var(--primary-color);cursor:pointer;font-size:.9375rem;font-weight:600;padding:0;transition:color .3s ease}.toggle-link:hover{color:#1d4ed8;color:var(--primary-hover);text-decoration:underline}.header-section{animation:fadeInDown .8s ease-out;margin-bottom:3rem;text-align:center}.header-top{align-items:center;display:flex;flex-wrap:nowrap;gap:.75rem 1rem;justify-content:space-between;margin-bottom:1rem}.user-email{background:#ffffff14;border:1px solid #ffffff24;border-radius:12px;box-shadow:0 10px 20px #0000002e;color:#e2e8f0;font-weight:700;letter-spacing:.01em;margin-right:.75rem;padding:.4rem .75rem}.logout-btn,.user-email{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.logout-btn{align-items:center;background:#ffffffb3;border:1px solid #94a3b84d;border:1px solid var(--border-color);border-radius:8px;color:#1e293b;color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;justify-content:center;padding:.625rem 1.25rem;transition:all .3s ease}.logout-btn:hover{background:#ffffffe6;border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 4px 12px #2563eb33;transform:translateY(-2px)}.logout-btn:active{transform:translateY(0)}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.logo-wrapper{align-items:center;display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.logo-icon{color:#fff;height:78px;width:78px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.logo-icon svg{filter:drop-shadow(0 0 20px rgba(99,102,241,.6));height:100%;width:100%}.title{color:#fff;font-size:2.6rem;font-weight:700;letter-spacing:-.02em}.subtitle{color:#475569;color:var(--text-secondary);font-size:1.125rem;font-weight:400;letter-spacing:.01em}.divider{background:linear-gradient(90deg,#0000,#2563eb,#0000);background:linear-gradient(90deg,#0000,var(--primary-color),#0000);border-radius:2px;height:4px;margin:1.5rem auto;width:100px}.main-content{animation:fadeInUp .8s ease-out .2s both}.portal-hero{align-items:stretch;background:linear-gradient(135deg,#22d3ee1f,#6366f129);border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 48px #00000047;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem;padding:1.5rem 1.75rem}.portal-hero-left{align-items:center;display:flex;flex:1 1;gap:1rem;min-width:0;width:100%}.portal-copy{display:flex;flex-direction:column;gap:.35rem;max-width:760px;width:100%}.portal-hero-logo{background:radial-gradient(circle at 30% 30%,#ffffff2e,#4f46e53d);border-radius:18px;box-shadow:0 12px 30px #00000038;display:grid;height:86px;place-items:center;width:86px}.portal-hero-logo svg{height:auto;width:64px}.portal-eyebrow{color:#cbd5e1;font-size:.8rem;font-weight:700;letter-spacing:.14em;margin:0 0 .25rem;text-transform:uppercase}.portal-title{color:#f8fafc;font-size:1.6rem;font-weight:800;line-height:1.3;margin:0;max-width:100%}.portal-subtitle{color:#e2e8f0;font-size:1rem;line-height:1.6;margin:.35rem 0 0;max-width:700px;white-space:normal;word-break:normal}.portal-hero-right{align-items:flex-end;display:flex;flex-direction:column;gap:.5rem;justify-content:center}.portal-patient-chip{background:#ffffff14;border:1px solid #ffffff29;border-radius:12px;box-shadow:0 10px 24px #0000002e;color:#f8fafc;display:flex;flex-direction:column;min-width:200px;padding:.65rem .85rem;text-align:right}.portal-chip-label{color:#cbd5e1;font-size:.72rem;letter-spacing:.08em;margin-bottom:.15rem;text-transform:uppercase}.portal-hero-actions{display:flex;flex-wrap:wrap;gap:.65rem;justify-content:flex-end}.portal-hero-actions button{padding:.75rem 1.2rem}.portal-action-btn,.portal-hero-actions button{border:none;border-radius:12px;color:#fff;cursor:pointer;font-weight:700;transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}.portal-action-btn,.portal-primary{padding:.65rem 1.1rem}.portal-primary{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:12px;box-shadow:0 12px 26px #14b8a659;color:#fff;cursor:pointer;font-weight:700}.portal-primary:hover{box-shadow:0 14px 32px #14b8a673;transform:translateY(-2px)}.portal-ghost{background:#ffffff14;border:1px solid #ffffff2e}.portal-ghost:hover{box-shadow:0 10px 22px #0000002e;transform:translateY(-2px)}.portal-danger{background:#ef4444e6;box-shadow:0 10px 22px #ef444459}.portal-danger:hover{box-shadow:0 12px 28px #ef444473;transform:translateY(-2px)}@media (max-width:960px){.portal-hero{align-items:stretch;flex-direction:column}.portal-hero-right{align-items:flex-start;width:100%}.portal-hero-actions{justify-content:flex-start}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.info-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;background:var(--card-bg);border:1px solid #94a3b84d;border:1px solid var(--border-color);border-radius:20px;box-shadow:0 20px 50px #0000001a;box-shadow:0 20px 50px var(--shadow-color);margin-bottom:2.5rem;padding:2rem;transition:transform .3s ease,box-shadow .3s ease}.info-card:hover{box-shadow:0 25px 60px #0000001a;box-shadow:0 25px 60px var(--shadow-color);transform:translateY(-5px)}.info-card h2{color:#1e293b;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:.75rem}.info-card p{color:#475569;color:var(--text-secondary);font-size:1.0625rem;line-height:1.6}.action-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.action-btn{align-items:center;border:none;border-radius:16px;box-shadow:0 10px 30px #0003;cursor:pointer;display:flex;font-size:1.125rem;font-weight:600;gap:1rem;justify-content:center;overflow:hidden;padding:1.5rem 2rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.action-btn:before{background:linear-gradient(135deg,#ffffff1a,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.action-btn:hover:before{opacity:1}.primary-btn{background:linear-gradient(135deg,#2563eb,#0ea5e9);background:linear-gradient(135deg,var(--primary-color) 0,var(--secondary-color) 100%);border:2px solid #0000;color:#fff}.primary-btn:hover{box-shadow:0 15px 40px #2563eb66;transform:translateY(-3px)}.primary-btn:active{transform:translateY(-1px)}.primary-btn.recording{animation:recordingPulse 2s ease-in-out infinite;background:linear-gradient(135deg,#06b6d4,#dc2626);background:linear-gradient(135deg,var(--accent-color) 0,#dc2626 100%)}@keyframes recordingPulse{0%,to{box-shadow:0 15px 40px #ec489966}50%{box-shadow:0 15px 50px #ec4899cc}}.secondary-btn{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;background:var(--card-bg);border:2px solid #94a3b84d;border:2px solid var(--border-color);color:#1e293b;color:var(--text-primary)}.secondary-btn:hover{border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 15px 40px #2563eb4d;transform:translateY(-3px)}.secondary-btn:active{transform:translateY(-1px)}.btn-icon{align-items:center;display:flex;height:28px;justify-content:center;width:28px}.btn-icon svg{height:100%;width:100%}.btn-text{position:relative;z-index:1}.recording-indicator{animation:blink 1s ease-in-out infinite;background:#fff;border-radius:50%;height:12px;position:absolute;right:1.5rem;width:12px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.divider-text{margin:.5rem 0;position:relative;text-align:center}.divider-text span{background:#fff;color:#475569;color:var(--text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.1em;padding:0 1rem;position:relative;text-transform:uppercase;z-index:1}.divider-text:before{background:#94a3b84d;background:var(--border-color);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.file-info{animation:slideIn .4s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.file-info-content{align-items:center;background:#10b9811a;border:1px solid #10b9814d;border-radius:12px;color:#10b981;color:var(--success-color);display:flex;font-size:.9375rem;gap:.75rem;padding:1rem 1.5rem}.file-info-content svg{flex-shrink:0;height:24px;width:24px}.drag-drop-zone{position:relative;width:100%}.drag-drop-zone.dragging .action-btn{background:#fff;border-color:#2563eb;border-color:var(--primary-color);border-style:dashed;border-width:3px;transform:scale(1.02)}.drag-drop-zone.dragging .action-btn .btn-icon,.drag-drop-zone.dragging .action-btn .btn-text{opacity:0;visibility:hidden}.drag-overlay{align-items:center;animation:fadeInScale .2s ease-out;bottom:0;display:flex;flex-direction:column;gap:.75rem;justify-content:center;left:0;padding:1.5rem;pointer-events:none;position:absolute;right:0;top:0;z-index:10}.drag-overlay svg{animation:bounce .6s ease-in-out infinite;filter:drop-shadow(0 2px 8px rgba(37,99,235,.3));height:48px;width:48px}.drag-overlay p,.drag-overlay svg{color:#2563eb;color:var(--primary-color)}.drag-overlay p{font-size:1.125rem;font-weight:700;letter-spacing:.02em;margin:0}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.pii-notification{animation:slideIn .4s ease-out;margin-bottom:1rem}.pii-notification-content{align-items:flex-start;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-left:4px solid #f59e0b;border-radius:12px;box-shadow:0 2px 8px #f59e0b26;color:#92400e;display:flex;font-size:.9375rem;gap:1rem;line-height:1.6;padding:1rem 1.5rem}.pii-notification-icon{color:#f59e0b;flex-shrink:0;height:24px;margin-top:2px;width:24px}.pii-notification-text{flex:1 1}.pii-notification-text strong{color:#78350f;display:block;font-weight:600;margin-bottom:.25rem}.pii-tags{display:inline-flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.pii-tag{background:#f59e0b33;border:1px solid #f59e0b4d;border-radius:6px;color:#92400e;display:inline-block;font-size:.8125rem;font-weight:600;letter-spacing:.025em;padding:.25rem .75rem}.recording-timer{animation:slideIn .4s ease-out;margin-top:1rem}.timer-content{align-items:center;background:#ec489926;border:1px solid #ec489966;border-radius:12px;color:#06b6d4;color:var(--accent-color);display:flex;font-size:1rem;font-weight:600;gap:.75rem;padding:1rem 1.5rem}.pulse-dot{animation:pulse-dot 1.5s ease-in-out infinite;background:#06b6d4;background:var(--accent-color);border-radius:50%;box-shadow:0 0 10px #ec4899cc;height:12px;width:12px}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.3)}}.audio-player-container{animation:slideIn .5s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;background:var(--card-bg);border:1px solid #94a3b84d;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 10px 30px #0000001a;box-shadow:0 10px 30px var(--shadow-color);margin-top:2rem;padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease}.audio-player-container:hover{box-shadow:0 15px 40px #0000001a;box-shadow:0 15px 40px var(--shadow-color);transform:translateY(-3px)}.audio-player-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.audio-player-header svg{color:#2563eb;color:var(--primary-color);flex-shrink:0;height:40px;width:40px}.audio-info h3{color:#1e293b;color:var(--text-primary);font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.audio-info p{color:#475569;color:var(--text-secondary);font-size:.875rem;margin:0}.audio-player{background:#0f172a99;border-radius:8px;transition:all .3s ease}.audio-player::-webkit-media-controls-panel{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:8px}.audio-player::-webkit-media-controls-pause-button,.audio-player::-webkit-media-controls-play-button{background-color:#2563eb;background-color:var(--primary-color);border-radius:50%}.audio-player::-webkit-media-controls-current-time-display,.audio-player::-webkit-media-controls-time-remaining-display{color:#1e293b;color:var(--text-primary);text-shadow:none}.audio-player::-webkit-media-controls-timeline,.audio-player::-webkit-media-controls-volume-slider{background:#94a3b833;border-radius:4px}.audio-player::-moz-range-track{background:#94a3b833;border-radius:4px}.audio-player::-moz-range-thumb{background:#2563eb;background:var(--primary-color);border:none;border-radius:50%}.generate-section{animation:slideIn .5s ease-out;margin-top:2rem}.generate-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;min-height:72px}.generate-row .generate-btn,.generate-row .new-recording-btn{align-self:stretch;height:72px;line-height:1.2;margin:0;min-height:72px;padding:0 2rem}.generate-btn,.generate-row .generate-btn,.generate-row .new-recording-btn{align-items:center;box-sizing:border-box;display:flex;flex:1 1;font-size:1.05rem;font-weight:700;gap:.75rem;justify-content:center}.generate-btn{background:linear-gradient(135deg,#10b981,#059669);border:2px solid #0000;border-radius:16px;box-shadow:0 10px 30px #10b9814d;min-width:200px;transition:all .3s cubic-bezier(.4,0,.2,1)}.generate-btn:before{background:linear-gradient(135deg,#fff3,#fff0)}.generate-btn:hover:not(:disabled){box-shadow:0 12px 32px #10b98180}.generate-btn:disabled{opacity:.7}.new-recording-btn{align-items:center;background:#fff;border:2px solid #94a3b859;border-radius:16px;box-shadow:0 8px 20px #0000001f;box-sizing:border-box;color:#111827;cursor:pointer;display:flex;flex:1 1;font-size:1.05rem;font-weight:700;gap:.75rem;justify-content:center;min-width:200px;overflow:hidden;position:relative;transition:all .3s ease}.new-recording-btn:before{background:linear-gradient(135deg,#ffffff80,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.new-recording-btn:hover:not(:disabled):before{opacity:1}.new-recording-btn:hover:not(:disabled){box-shadow:0 10px 24px #0000002e;transform:translateY(-2px)}.new-recording-btn:active:not(:disabled){transform:translateY(-1px)}.new-recording-btn:disabled{cursor:not-allowed;opacity:.6}.generate-warning{background:#fffbea;border:1px solid #f6ad55;border-radius:8px;color:#744210;font-size:.95rem;margin-bottom:.75rem;padding:.75rem 1rem}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{align-items:center;animation:slideIn .4s ease-out;background:#ef444426;color:#ef4444;display:flex;font-size:.9375rem;gap:.75rem;margin-top:1.5rem;padding:1rem 1.5rem}.error-message svg{flex-shrink:0;height:24px;width:24px}.soap-note-container{animation:slideIn .6s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffe6;background:var(--card-bg);border:1px solid #94a3b84d;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 10px 30px #0000001a;box-shadow:0 10px 30px var(--shadow-color);margin-top:2rem;padding:2rem}.soap-note-header{align-items:center;border-bottom:1px solid #94a3b84d;border-bottom:1px solid var(--border-color);display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem}.soap-note-header svg{color:#10b981;color:var(--success-color);flex-shrink:0;height:32px;width:32px}.soap-note-header h3{color:#1e293b;color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:0}.soap-note-content{border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.soap-note-content pre{word-wrap:break-word;color:#475569;color:var(--text-secondary);font-family:Monaco,Courier New,monospace;font-size:.875rem;line-height:1.6;margin:0;white-space:pre-wrap}.soap-note-content::-webkit-scrollbar{width:8px}.soap-note-content::-webkit-scrollbar-track{background:#94a3b81a;border-radius:4px}.soap-note-content::-webkit-scrollbar-thumb{background:#94a3b84d;border-radius:4px}.soap-note-content::-webkit-scrollbar-thumb:hover{background:#94a3b880}.cta-section{animation:fadeInUp .8s ease-out .4s both;margin:3rem 0}.cta-shell{background:linear-gradient(135deg,#2563eb24,#0ea5e91a,#a855f71f);border:1px solid #ffffff24;border-radius:28px;box-shadow:0 20px 50px #00000047;overflow:hidden;padding:2.5rem;position:relative}.cta-shell:before{background:radial-gradient(circle at 20% 20%,#ffffff14,#0000 38%),radial-gradient(circle at 80% 30%,#4f46e52e,#0000 40%),radial-gradient(circle at 50% 80%,#22d3ee24,#0000 38%);content:"";filter:blur(16px);inset:0;pointer-events:none;position:absolute}.cta-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1.3fr 1fr;position:relative;z-index:1}.cta-left{display:flex;flex-direction:column;gap:1rem}.cta-badge{align-items:center;background:#ffffff29;border-radius:999px;color:#e2e8f0;display:inline-flex;font-weight:700;gap:.4rem;letter-spacing:.04em;padding:.4rem .85rem;width:-webkit-fit-content;width:fit-content}.cta-title{color:#fff;font-size:clamp(2rem,3vw,2.4rem);font-weight:800;line-height:1.2;margin:0}.cta-description{color:#e2e8f0;font-size:1.05rem;line-height:1.7;margin:0;max-width:720px}.cta-list{grid-gap:.65rem;display:grid;gap:.65rem;margin:.5rem 0 0}.cta-list-item{align-items:center;color:#dbeafe;display:flex;font-weight:600;gap:.65rem}.cta-dot{background:linear-gradient(135deg,#22d3ee,#6366f1);border-radius:50%;box-shadow:0 0 12px #6366f180;flex-shrink:0;height:10px;width:10px}.cta-actions{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin-top:.75rem}.cta-button{align-items:center;background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:14px;box-shadow:0 15px 38px #14b8a659;color:#fff;cursor:pointer;display:inline-flex;font-size:1.05rem;font-weight:700;gap:.75rem;justify-content:center;padding:1.1rem 2.2rem;transition:all .25s ease}.cta-button:hover{box-shadow:0 18px 42px #14b8a673;transform:translateY(-2px)}.cta-button:active{transform:translateY(0)}.cta-btn-icon{align-items:center;display:flex;height:22px;justify-content:center;width:22px}.cta-btn-icon svg{height:100%;width:100%}.cta-note{color:#cbd5e1;font-size:.92rem;margin:0;opacity:.9}.cta-logo-card,.cta-right{align-items:center;display:flex;justify-content:center}.cta-logo-card{background:none;border:none;border-radius:18px;box-shadow:0 18px 46px #00000047;flex-direction:column;gap:0;max-width:420px;min-height:320px;padding:0;position:relative;width:100%}.cta-logo-hero{display:block;height:auto;margin:0 auto;width:280px}@media (max-width:1024px){.cta-grid{grid-template-columns:1fr}.cta-right{justify-content:flex-start}}@media (max-width:640px){.cta-shell{padding:1.75rem}.cta-stat-row{grid-template-columns:1fr}}@media (max-width:760px){.container{padding:1.25rem}.header-top{align-items:center;flex-direction:row;gap:.75rem}.header-top>div:last-child{align-items:center;display:inline-flex;flex-shrink:1;gap:.5rem;justify-content:flex-end}.header-top>div:last-child .user-email{display:none}.portal-hero{flex-direction:column;gap:.75rem;padding:1rem}.portal-hero-left,.portal-hero-right{align-items:flex-start}.portal-patient-chip{font-size:.9rem}.portal-action-btn{min-width:120px;padding:.6rem 1rem;text-align:center;width:auto}.action-btn,.primary-btn,.secondary-btn{width:100%}.portal-title{font-size:1.25rem;line-height:1.35;max-width:100%;text-align:left}.portal-subtitle{font-size:.9rem;line-height:1.5;max-width:100%;text-align:left}.logo-icon{height:64px;width:64px}.title{font-size:2rem}}.footer{animation:fadeIn 1s ease-out .6s both;margin-top:3rem;text-align:center}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.footer p{color:#475569;color:var(--text-secondary);font-size:.875rem;opacity:.7}.patient-panel{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:1.5rem}.patient-field{display:flex;flex-direction:column;gap:.35rem}.field-label{color:#e2e8f0;font-size:.95rem;font-weight:700}.field-input{background-color:#ffffff0f;border:1px solid #ffffff2e;border-radius:12px;color:#e2e8f0;font-size:1rem;outline:none;padding:.85rem;transition:border-color .2s,box-shadow .2s;width:100%}.field-input:focus{border-color:#63b3ed;box-shadow:0 0 0 3px #63b3ed40}.field-error{align-items:center;color:#ef4444;display:flex;font-size:.875rem;gap:.5rem;margin-top:.35rem}.patient-search-container{position:relative}.input-clear{align-items:center;background:#0000;border:none;color:#a0aec0;cursor:pointer;display:flex;justify-content:center;padding:.25rem;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:color .2s}.input-clear:hover{color:#e2e8f0}.patient-dropdown{background-color:#0f172ad9;border:1px solid #ffffff1f;box-shadow:0 14px 30px #00000059;margin-top:.25rem;max-height:300px;overflow-y:auto;z-index:1000}.patient-dropdown-item{background-color:initial;border-bottom:1px solid #ffffff0a;cursor:pointer;padding:.75rem 1rem;transition:background-color .15s}.patient-dropdown-item:last-child{border-bottom:none}.patient-dropdown-item:hover{background-color:#ffffff0f}.patient-dropdown-item.is-selected{background-color:#63b3ed1f}.patient-empty{color:#a0aec0;font-size:.875rem;padding:1.25rem;text-align:center}.patient-name{color:#e2e8f0;margin-bottom:.1rem}.patient-info{color:#cbd5e1;display:flex;flex-wrap:wrap;font-size:.875rem;gap:.75rem}.patient-summary{background-color:#0f172acc;border:1px solid #ffffff1f;border-radius:12px;color:#e2e8f0;display:flex;flex-direction:column;font-size:.9rem;gap:.25rem;margin-top:.5rem;padding:.9rem;position:relative}.patient-meta{color:#94a3b8;font-size:.85rem}.patient-actions{gap:.5rem;margin-top:.5rem}.patient-actions .portal-ghost,.patient-actions .portal-primary{align-items:center;border-radius:12px;box-shadow:0 10px 24px #00000026;cursor:pointer;display:inline-flex;font-weight:700;gap:.45rem;justify-content:center;min-width:140px;padding:.65rem 1.1rem;transition:.2s ease-in-out}.patient-actions .portal-ghost{background:#ffffff14;border:1px solid #fff3;color:#e2e8f0}.patient-actions .portal-ghost:hover,.patient-actions .portal-primary:hover{box-shadow:0 12px 30px #0003;transform:translateY(-2px)}@media (max-width:768px){.patient-panel{grid-template-columns:1fr}.patient-dropdown-item{min-height:60px;padding:1rem}.patient-name{font-size:1rem}.patient-info{font-size:.875rem}.logo-icon{display:none}.logo-wrapper .title{display:block!important;font-size:1.5rem;font-weight:700}.logo-wrapper{gap:0;justify-content:flex-start;margin-top:.25rem}.header-top{padding:0 .5rem}.header-top button{align-items:center;display:inline-flex;font-size:.875rem;justify-content:center;min-width:auto;padding:.75rem 1rem}}.mobile-close-button{display:none}@media (max-width:768px){.soap-note-header>button{display:none!important}.mobile-close-button{display:block!important;margin-bottom:1rem;text-align:center;width:100%}.mobile-close-button button{align-items:center;background:#0000;border:none;border-radius:50%;color:#000;cursor:pointer;display:inline-flex;font-size:2.5rem;font-weight:300;height:64px;justify-content:center;line-height:1;padding:.75rem;transition:all .3s ease;width:64px}.mobile-close-button button:hover{background:#2563eb26;color:#2563eb;color:var(--primary-color);transform:translateY(-2px)}.mobile-close-button button:active{transform:translateY(0)}}.soap-note-header{width:100%}.soap-note-header>div:first-child{flex:1 1;min-width:0}.soap-note-header h3{word-wrap:break-word;overflow-wrap:break-word}@media (max-width:768px){.app-page-container{max-width:100%!important}.app-page-container,.container{padding:.5rem!important}input[type=date]{box-sizing:border-box;font-size:1rem;max-width:100%;padding:.75rem;width:100%}.soap-note-container{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:5px!important;width:100%!important}.soap-note-header{align-items:center!important;flex-direction:row!important;gap:.5rem!important;margin-bottom:.5rem!important;padding-bottom:.5rem!important;padding-left:0!important;padding-right:0!important}.soap-note-header>div:first-child{flex:1 1;min-width:0}.soap-note-header h3{font-size:.95rem!important;line-height:1.3!important}.soap-action-buttons{flex-wrap:wrap!important;gap:.5rem!important;justify-content:center!important}.soap-action-buttons,.soap-note-content{margin-left:0!important;margin-right:0!important;padding:5px!important}.soap-note-content{max-height:none!important;overflow-y:visible!important}.pii-notification{margin-left:0!important;margin-right:0!important}.pii-notification-content{padding:.5rem 5px!important}.soap-action-buttons button:first-child,.soap-action-buttons button:nth-child(2){flex-basis:calc(50% - 0.25rem);flex-grow:1;flex-shrink:1}.soap-action-buttons button:first-child,.soap-action-buttons button:nth-child(2),.soap-action-buttons button:nth-child(3){align-items:center!important;display:flex!important;font-size:.85rem!important;justify-content:center!important;max-width:none!important;min-width:0!important;padding:.75rem .5rem!important;white-space:nowrap!important}.soap-action-buttons button:nth-child(3){flex:1 1 100%!important}.soap-action-buttons button svg{height:16px!important;width:16px!important}}@media (max-width:850px){.App{cursor:auto}}@media (max-width:1024px){.auth-wrapper{max-width:100%;padding:0 1.25rem}.auth-container{max-width:100%;width:100%}}@media (max-width:1100px){.auth-wrapper{max-width:100%;padding:0 .75rem}.auth-back-row{padding-left:.25rem}.auth-container{grid-template-columns:1fr;margin:0 auto;max-width:100%;min-height:85vh;min-width:0;width:100%}.auth-left{border-radius:24px 24px 0 0;padding:2.5rem 2rem}.auth-right{border-radius:0 0 24px 24px;padding:2.5rem 2rem}}@media (max-width:768px){.container{padding:1.5rem}.pii-notification-content{gap:.75rem;padding:.875rem 1.25rem}.pii-notification-icon{height:20px;width:20px}.pii-notification-text strong{font-size:.875rem}.pii-tags{gap:.375rem;margin-top:.375rem}.pii-tag{font-size:.75rem;padding:.2rem .6rem}.auth-wrapper{max-width:100%;padding:0 1rem}.auth-container{border-radius:20px;grid-template-columns:1fr;margin:0 auto;max-width:100%;min-height:85vh;min-width:0;width:100%}.auth-left{border-radius:20px 20px 0 0;padding:2rem 1.5rem}.logo-icon-large{height:80px;width:80px}.logo-icon-large svg{height:40px;width:40px}.auth-brand{font-size:2rem}.auth-tagline{font-size:1rem}.auth-right{border-radius:0 0 20px 20px;padding:2rem 1.5rem}.auth-title{font-size:1.5rem}.auth-form{gap:1.25rem}.form-group input{font-size:.9375rem;padding:.75rem .875rem}.auth-button{font-size:.9375rem;padding:.875rem 1.75rem}.title{font-size:2rem}.subtitle{font-size:1rem}.info-card{padding:1.5rem}.info-card h2{font-size:1.5rem}.action-btn,.info-card p{font-size:1rem}.action-btn{padding:1.25rem 1.5rem}.btn-icon{height:24px;width:24px}.logo-wrapper{flex-direction:column;gap:.5rem}.audio-player-container{padding:1.25rem}.audio-player-header svg{height:32px;width:32px}.audio-info h3{font-size:1rem}.carousel-controls{margin-top:1rem}.generate-btn,.new-recording-btn{flex:1 1 100%}.soap-note-container{padding:1.5rem}.soap-note-header h3{font-size:1.25rem}.cta-content{padding:2.5rem 1.5rem}.cta-title{font-size:1.75rem}.cta-button,.cta-description{font-size:1rem}.cta-button{padding:1.125rem 2rem}}@media (max-width:500px){.container{padding:1rem}.pii-notification-content{flex-direction:column;gap:.5rem;padding:.75rem 1rem}.pii-notification-icon{height:18px;margin-top:0;width:18px}.pii-tags{gap:.25rem}.pii-tag{font-size:.7rem;padding:.15rem .5rem}.auth-wrapper{max-width:100%;padding:0 .75rem;width:100%}.auth-container{border-radius:16px;max-width:100%;min-height:82vh;min-width:0;width:100%}.auth-left{border-radius:16px 16px 0 0;padding:1.5rem 1.25rem}.auth-right{border-radius:0 0 16px 16px;padding:1.5rem 1.25rem}.logo-icon-large{height:70px;width:70px}.logo-icon-large svg{height:36px;width:36px}.auth-brand{font-size:1.75rem}.auth-tagline{font-size:.9375rem}.auth-title{font-size:1.25rem;margin-bottom:1rem}.auth-form{gap:1rem}.form-group label{font-size:.8125rem}.form-group input{padding:.75rem .875rem}.auth-button,.form-group input{border-radius:10px;font-size:.875rem}.auth-button{padding:.875rem 1.5rem}.auth-toggle p,.toggle-link{font-size:.875rem}.title{font-size:1.75rem}.subtitle{font-size:.9375rem}.info-card{padding:1.25rem}.info-card h2{font-size:1.25rem}.action-btn{font-size:.9375rem;padding:1rem 1.25rem}.audio-player-container{padding:1rem}.audio-player-header{align-items:flex-start;flex-direction:column;gap:.75rem}.audio-info h3{font-size:.9375rem}.audio-info p{font-size:.8125rem}.timer-content{font-size:.9375rem}.generate-btn,.new-recording-btn{flex:1 1 100%}.soap-note-container{padding:1.25rem}.soap-note-header{align-items:flex-start;flex-direction:column}.soap-note-header h3{font-size:1.125rem}.soap-note-content{max-height:400px;padding:1rem}.soap-note-content pre{font-size:.8125rem}.error-message{font-size:.875rem;padding:.875rem 1.25rem}.cta-content{padding:2rem 1.25rem}.cta-icon{height:56px;width:56px}.cta-icon svg{height:32px;width:32px}.cta-title{font-size:1.5rem}.cta-button,.cta-description{font-size:.9375rem}.cta-button{padding:1rem 1.75rem}.cta-note{font-size:.8125rem}.auth-legal-links{flex-direction:column;gap:.5rem;margin-top:1.25rem;padding-top:1.25rem}.legal-separator{display:none}.legal-link{font-size:.8125rem}}@media (max-width:380px){.auth-wrapper{padding:0 .5rem}.auth-container{border-radius:12px;max-width:100%;min-height:82vh;min-width:0;width:100%}.auth-left{border-radius:12px 12px 0 0;padding:1.25rem 1rem}.auth-right{border-radius:0 0 12px 12px;padding:1.25rem 1rem}.logo-icon-large{height:60px;width:60px}.logo-icon-large svg{height:32px;width:32px}.auth-brand{font-size:1.5rem}.auth-tagline{font-size:.875rem}.auth-title{font-size:1.125rem}.auth-form{gap:.875rem}.form-group label{font-size:.75rem}.form-group input{padding:.625rem .75rem}.auth-button,.form-group input{border-radius:8px;font-size:.8125rem}.auth-button{padding:.75rem 1.25rem}.auth-toggle{margin-top:1rem;padding-top:1rem}.auth-toggle p,.toggle-link{font-size:.8125rem}.info-card{padding:1rem}.info-card h2{font-size:1.125rem}.action-btn{font-size:.875rem;padding:.875rem 1rem}.carousel-dots{gap:.25rem;margin-top:.875rem}.dot{height:7px;width:7px}.dot.active{width:18px}.auth-legal-links{gap:.375rem;margin-top:1rem;padding-top:1rem}.legal-link{font-size:.75rem;padding:.25rem}}html{scroll-behavior:smooth}.action-btn:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-color);outline-offset:4px}input[type=file]:focus-visible+label{outline:2px solid #2563eb;outline:2px solid var(--primary-color);outline-offset:4px}.dot:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-color);outline-offset:2px}.generate-btn:focus-visible{outline:2px solid #10b981;outline:2px solid var(--success-color);outline-offset:4px}.new-recording-btn:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-color);outline-offset:4px}.cta-button:focus-visible{outline:2px solid #2563eb;outline:2px solid var(--primary-color);outline-offset:4px}.auth-legal-links{align-items:center;border-top:1px solid #e2e8f0;display:flex;gap:1rem;justify-content:center;margin-top:1.5rem;padding-top:1.5rem}.legal-link{background:none;border:none;border-radius:4px;color:#4299e1;cursor:pointer;font-size:.875rem;font-weight:500;padding:.25rem .5rem;text-decoration:none;transition:all .2s ease}.legal-link:hover{background:#4299e11a;color:#2c5282;text-decoration:underline}.legal-link:focus-visible{outline:2px solid #4299e1;outline-offset:2px}.legal-separator{color:#cbd5e0;font-size:.875rem}.legal-page-container{margin:2rem auto 3rem;max-width:900px;padding:0 1.5rem 2.5rem}.legal-header{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:18px;box-shadow:0 18px 36px #00000047;color:#e2e8f0;margin-bottom:2rem;padding:1.5rem 1.75rem}.legal-header-top{justify-content:space-between;margin-bottom:1rem}.back-btn,.legal-header-top{align-items:center;display:flex}.back-btn{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:8px;box-shadow:0 12px 28px #14b8a659;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s ease}.back-btn:hover{box-shadow:0 14px 32px #14b8a673;transform:translateY(-2px)}.back-btn:active{transform:translateY(0)}.back-btn svg{height:20px;width:20px}.legal-content{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:18px;box-shadow:0 18px 36px #00000047;color:#cbd5e1;line-height:1.7;padding:2.5rem}.legal-title{border-bottom:3px solid #14b8a6b3;color:#f8fafc;font-size:2.5rem;font-weight:700;margin-bottom:.5rem;padding-bottom:1rem}.legal-date{color:#e2e8f0bf;font-size:.95rem;font-style:italic;margin-bottom:2rem}.legal-section{margin-bottom:3rem}.legal-section h2{border-bottom:2px solid #ffffff1f;color:#a7f3d0;font-size:1.75rem;font-weight:700;margin-bottom:1rem;margin-top:2rem;padding-bottom:.5rem}.legal-section h3{color:#e2e8f0;font-size:1.35rem;font-weight:600;margin-bottom:.75rem;margin-top:1.5rem}.legal-section h4{color:#e2e8f0d9;font-size:1.1rem;font-weight:600;margin-bottom:.5rem;margin-top:1rem}.legal-section p{color:#cbd5e1;font-size:1.05rem;line-height:1.8;margin-bottom:1rem}.legal-section ul{margin-bottom:1rem;margin-left:2rem}.legal-section li{color:#e2e8f0;font-size:1.05rem;line-height:1.7;margin-bottom:.75rem}.legal-section li ul{margin-left:1.5rem;margin-top:.5rem}.legal-section li ul li{font-size:1rem;margin-bottom:.5rem}.legal-section strong{color:#f8fafc;font-weight:600}.legal-section a{color:#5eead4;font-weight:500;text-decoration:underline;transition:all .2s ease}.legal-section a:hover{color:#a7f3d0}.warning-text{background:#14b8a61f;border-left:4px solid #14b8a6;border-radius:6px;color:#e2e8f0;font-weight:600;margin:1.5rem 0;padding:1rem 1.5rem}.legal-footer{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 36px #00000047;margin-top:2rem;padding:2rem;text-align:center}.legal-footer p{color:#cbd5e1;font-size:1rem;margin:.5rem 0}.legal-footer p:first-child{color:#f8fafc;font-weight:600}.scroll-to-top-btn{align-items:center;background:linear-gradient(135deg,#0f9b8e,#14b8a6);border:none;border-radius:999px;bottom:2rem;box-shadow:0 10px 25px #14b8a666;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;height:48px;justify-content:center;position:fixed;right:2rem;transition:transform .2s ease,opacity .2s ease;width:48px;z-index:1000}.scroll-to-top-btn:hover{transform:translateY(-4px)}.scroll-to-top-btn:focus{outline:2px solid #fff9;outline-offset:2px}@media (max-width:768px){.legal-page-container{padding:0 1rem 1rem}.legal-content{padding:2rem 1.5rem}.legal-title{font-size:2rem}.legal-section h2{font-size:1.5rem}.legal-section h3{font-size:1.2rem}.legal-header-top{align-items:stretch;flex-direction:column;gap:1rem}.back-btn{justify-content:center;width:100%}.legal-section ul{margin-left:1.5rem}}@media (max-width:480px){.legal-content{padding:1.5rem 1rem}.legal-title{font-size:1.75rem}.legal-section h2{font-size:1.3rem}.legal-section li,.legal-section p{font-size:1rem}.auth-legal-links{flex-direction:column;gap:.75rem}.legal-separator{display:none}.scroll-to-top-btn{bottom:1.25rem;height:44px;right:1.25rem;width:44px}}@media (max-width:768px){.main-content{padding:.5rem!important}.main-content>div:first-child{margin-bottom:1rem!important;padding:1.5rem 1rem!important}.main-content>div:first-child h2{font-size:1.5rem!important;line-height:1.3!important}.main-content>div:first-child p{font-size:.95rem!important;line-height:1.5!important}.main-content>div:last-child{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;margin:0!important;padding:0!important}.main-content>div:last-child>div:first-child{align-items:flex-start!important;gap:.75rem!important;padding:.5rem!important}.main-content>div:last-child>div:first-child>div:first-child{height:40px!important;width:40px!important}.main-content>div:last-child>div:first-child h3{font-size:1.35rem!important}.main-content>div:last-child>div:first-child p{font-size:.85rem!important}.main-content button[style*="display: flex"]{font-size:.9rem!important;justify-content:center!important;padding:.75rem 1rem!important;width:100%!important}.main-content div[style*=grid-template-columns]{gap:1rem!important;grid-template-columns:1fr!important}.main-content>div:last-child>div:last-child>div{margin-bottom:.75rem!important;margin-left:0!important;margin-right:0!important;padding:.75rem!important}.main-content>div:last-child>div:last-child>div>div:first-child{align-items:flex-start!important;flex-direction:column!important;gap:.5rem!important;padding:0!important}.main-content>div:last-child>div:last-child>div>div:first-child h4{font-size:1.1rem!important}.main-content>div:last-child>div:last-child>div>div:first-child p{font-size:.85rem!important}.main-content>div:last-child>div:last-child>div>div:nth-child(2){flex-wrap:wrap!important;gap:.5rem!important}.main-content>div:last-child>div:last-child>div>div:nth-child(2) button{flex:1 1!important;font-size:.85rem!important;min-width:calc(50% - .25rem)!important;padding:.65rem .75rem!important;white-space:nowrap!important}.main-content>div:last-child>div:last-child>div>div:last-child{padding:.5rem!important}.main-content>div:last-child>div:last-child>div>div:last-child h4{font-size:1.1rem!important;margin-bottom:.5rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div{margin-bottom:.75rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div>div:first-child{font-size:.95rem!important;padding:.5rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div>div:last-child{font-size:.875rem!important;padding:.5rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div[style*=linear-gradient]{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:.5rem!important}.main-content div[style*="border: 1px solid rgb(226, 232, 240)"][style*="padding: 1.5rem"]{background:#0000!important;padding:.5rem!important}.main-content div[style*="linear-gradient(to right bottom"][style*="padding: 1rem"]{background:#0000!important;border:none!important;border-radius:0!important;box-shadow:none!important;padding:.5rem!important}.main-content button[style*=gradient]{font-size:.9rem!important;padding:.75rem 1.25rem!important}}@media (max-width:500px){.main-content{padding:.75rem!important}.main-content>div:first-child{border-radius:16px!important;margin-bottom:1.5rem!important;padding:1.5rem 1rem!important}.main-content>div:first-child h2{font-size:1.25rem!important}.main-content>div:first-child p{font-size:.875rem!important}.main-content>div:last-child{border-radius:12px!important;padding:1rem!important}.main-content>div:last-child>div:last-child>div{border-radius:10px!important;padding:1rem!important}.main-content>div:last-child>div:last-child>div>div:first-child h4{font-size:1rem!important}.main-content>div:last-child>div:last-child>div>div:nth-child(2) button{font-size:.8rem!important;padding:.6rem .5rem!important}.main-content>div:last-child>div:last-child>div>div:last-child{padding:1rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div>div:first-child{font-size:.95rem!important;padding:.6rem!important}.main-content>div:last-child>div:last-child>div>div:last-child>div>div:last-child{font-size:.85rem!important;line-height:1.5!important;padding:.75rem!important}.header-top>div:first-child span{font-size:.8rem!important;max-width:150px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}}.patient-portal-layout{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem 0}.patient-hero .portal-title{max-width:640px}.patient-hero .portal-subtitle{max-width:700px}.patient-records-shell{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffff0a;border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 46px #00000047;padding:1.75rem;width:100%}.records-header-row{flex-wrap:nowrap;justify-content:space-between;margin-bottom:1.25rem}.records-header-row,.records-title-row{align-items:center;display:flex;gap:1rem;width:100%}.records-title-row{flex-wrap:wrap;min-width:0}.records-icon{background:linear-gradient(135deg,#6366f12e,#22d3ee38);border-radius:14px;box-shadow:0 12px 28px #00000040;color:#fff;display:grid;height:56px;place-items:center;width:56px}.records-heading{color:#f8fafc;display:inline-block;font-size:1.4rem;font-weight:800;margin:0;padding:.1rem .25rem}.records-subheading{color:#cbd5e1;font-size:.98rem;margin:.15rem 0 0}.filter-toggle{align-items:center;background:#ffffff0f;border:1px solid #ffffff24;border-radius:12px;color:#e2e8f0;cursor:pointer;display:inline-flex;font-weight:700;gap:.5rem;padding:.75rem 1.25rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap}.filter-toggle.active{background:linear-gradient(135deg,#22d3ee,#6366f1);border-color:#0000;box-shadow:0 12px 30px #6366f159}.filter-toggle:hover{box-shadow:0 10px 24px #0000002e;transform:translateY(-2px)}.records-filter-panel{background:linear-gradient(135deg,#2563eb14,#0ea5e914);border:1px solid #ffffff1f;border-radius:14px;margin-bottom:1.25rem;padding:1.25rem}.filter-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.filter-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-end;margin-top:.85rem}.filter-actions .portal-ghost,.filter-actions .portal-primary{border-radius:12px;font-weight:700;padding:.65rem 1.1rem}.filter-actions .portal-ghost{background:#ffffff14;border:1px solid #ffffff29;box-shadow:0 10px 22px #0000001f;color:#e2e8f0;transition:.2s ease-in-out}.filter-actions .portal-ghost:hover{background:#ffffff1f;box-shadow:0 12px 30px #0000002e;transform:translateY(-2px)}.patient-note-list{grid-gap:1.25rem;align-items:start;display:grid;gap:1.25rem;grid-auto-flow:row;grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}.patient-note-card{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:linear-gradient(160deg,#0f172a99,#6366f11f 35%,#22d3ee14);border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 36px #00000057;color:#e2e8f0;isolation:isolate;overflow:hidden;padding:0;position:relative;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.patient-note-card:before{background:radial-gradient(140% 80% at 15% 15%,#6366f129,#0000 55%),radial-gradient(110% 70% at 85% 20%,#22d3ee24,#0000 45%);content:"";inset:0;opacity:.9;position:absolute;z-index:-1}.patient-note-card.open,.patient-note-card:hover{border-color:#ffffff2e;box-shadow:0 22px 48px #00000061;transform:translateY(-2px)}.patient-note-card.open{grid-column:1/-1;margin-left:auto;margin-right:auto;max-width:1100px;order:-1}.patient-note-card.hidden-when-open{display:none}.note-summary{align-items:flex-start;background:linear-gradient(180deg,#ffffff05,#ffffff03);border:none;border-bottom:1px solid #ffffff14;color:inherit;cursor:pointer;display:flex;gap:1rem;justify-content:space-between;padding:1.2rem 1.35rem;text-align:left;width:100%}.note-summary:hover{background:#ffffff0a}.note-summary-left{grid-gap:.3rem;display:grid;gap:.3rem;min-width:0}.note-summary-right{align-items:flex-start;display:flex;gap:.65rem}.note-card-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.note-title{color:#fff;font-size:1.12rem;font-weight:800;margin:0}.note-meta{align-items:center;color:#cbd5e1;display:flex;font-size:.92rem;gap:.35rem;margin:0}.note-preview{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#cbd5e1;display:-webkit-box;font-size:.93rem;line-height:1.45;overflow:hidden}.note-caret{color:#cbd5e1;transition:transform .2s ease}.note-caret.open{transform:rotate(180deg)}.note-expand{grid-gap:.75rem;background:linear-gradient(180deg,#ffffff05,#ffffff0f);display:grid;gap:.75rem;padding:1.1rem 1.35rem 1.35rem}.note-tags{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:flex-end}.note-chip{align-items:center;border:1px solid #ffffff24;border-radius:999px;display:inline-flex;font-size:.8rem;font-weight:700;justify-content:center;padding:.3rem .6rem}.note-chip-success{background:#22c55e33;color:#bbf7d0}.note-chip-danger{background:#ef444433;color:#fecdd3}.note-chip-info{background:#60a5fa2e;color:#bfdbfe}.note-body{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.note-soap{grid-gap:.65rem;display:grid;gap:.65rem}.note-line{border-bottom:1px solid #ffffff14;padding:.65rem 0}.note-line:last-child{border-bottom:none}.note-section{background:#ffffff08;border:1px solid #ffffff1a;border-radius:12px;box-shadow:inset 0 1px 0 #ffffff0d;padding:.9rem}.note-section.glass{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0f;border-color:#ffffff24}.note-label{color:#c7d2fe;font-size:.9rem;font-weight:700;margin-bottom:.35rem}.note-section p{color:#e5e7eb;font-size:.95rem;line-height:1.5;margin:0}.note-footer{border-top:1px solid #ffffff14;color:#cbd5e1;display:flex;flex-wrap:wrap;font-size:.9rem;gap:1rem;margin-top:.5rem;padding-top:.75rem}.note-tabs{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:12px;display:inline-flex;gap:.5rem;padding:.35rem}.note-tab{background:#0000;border:none;border-radius:10px;color:#cbd5e1;cursor:pointer;font-weight:700;padding:.55rem .9rem;transition:all .2s ease}.note-tab.active{background:linear-gradient(135deg,#22d3ee,#6366f1);box-shadow:0 10px 26px #6366f14d;color:#fff}@media (max-width:760px){.patient-portal-layout{gap:1rem;padding:.75rem}.patient-records-shell{padding:1.1rem}.records-header-row{flex-direction:column;flex-wrap:wrap;gap:.75rem}.records-header-row,.records-title-row{align-items:flex-start;width:100%}.note-body,.patient-note-list{grid-template-columns:1fr}.filter-actions{flex-direction:column}}.history-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(circle at 20% 20%,#4f46e540,#0000 35%),radial-gradient(circle at 80% 30%,#22d3ee33,#0000 40%),#04060ed1;display:flex;inset:0;justify-content:center;padding:1.5rem;position:fixed;z-index:1200}.history-modal{background:linear-gradient(135deg,#0c1220f2,#0a0e1aeb);border:1px solid #ffffff1f;border-radius:20px;box-shadow:0 24px 60px #0006;display:flex;flex-direction:column;max-height:90vh;overflow:hidden;width:min(1200px,96vw)}.history-modal-header{align-items:center;border-bottom:1px solid #ffffff1f;display:flex;gap:1rem;justify-content:space-between;padding:1.5rem 1.75rem}.history-header-left{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.history-title{color:#f8fafc;font-size:1.8rem;font-weight:800;margin:0}.history-filter-toggle{background:#ffffff14;border:1px solid #ffffff29;border-radius:12px;color:#e2e8f0;font-weight:700;gap:.5rem;padding:.65rem 1rem}.history-close{background:#ffffff14;border:1px solid #ffffff1f;border-radius:12px;color:#cbd5e1;display:inline-flex;font-size:1.5rem;height:42px;transition:all .2s ease;width:42px}.history-close:hover{background:#ffffff26;color:#fff;transform:translateY(-2px)}.history-filter-panel{background:#ffffff0a;border-bottom:1px solid #ffffff1f;padding:1.25rem 1.75rem}.history-filter-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:.75rem}.history-filter-field label{color:#e2e8f0;display:block;margin-bottom:.35rem}.history-filter-input{background:#ffffff0f;border:1px solid #ffffff24;color:#e2e8f0}.history-filter-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;justify-content:space-between}.history-filter-reset{align-items:center;background:#ffffff0f;border:1px solid #ffffff29;border-radius:12px;color:#e5e7eb;cursor:pointer;display:inline-flex;font-weight:700;justify-content:center;padding:.65rem 1.1rem;transition:.3s ease-in-out}.history-filter-reset:hover{background:#ffffff14;box-shadow:0 10px 22px #0000002e;transform:translateY(-2px)}.history-results-chip{background:#10b9811f;border:1px solid #10b98159;border-radius:12px;color:#bbf7d0;font-size:.95rem;font-weight:700;padding:.55rem 1rem}.history-modal-body{flex:1 1;overflow-y:auto;padding:1.75rem}.history-empty{padding:2.5rem 1rem}.history-empty h3{color:#f8fafc;margin:.5rem 0}.history-empty p{color:#cbd5e1;margin:0}.history-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.history-card{background:linear-gradient(160deg,#ffffff0f,#ffffff08);border:1px solid #ffffff24;border-radius:16px;box-shadow:0 18px 38px #00000040;color:#e2e8f0;cursor:pointer;padding:1.25rem;position:relative;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,opacity .2s ease}.history-card:hover{border-color:#6366f166;box-shadow:0 20px 46px #0000004d;transform:translateY(-4px)}.history-card.is-disabled{cursor:not-allowed;opacity:.7}.history-delete{align-items:center;background:linear-gradient(135deg,#ef4444,#c53030);border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;height:34px;justify-content:center;position:absolute;right:.75rem;top:.75rem;transition:transform .2s ease,box-shadow .2s ease;width:34px}.history-delete:hover{box-shadow:0 10px 18px #ef444459;transform:translateY(-2px)}.history-card-header h3{color:#f8fafc;font-size:1.1rem;font-weight:800;margin:0 0 .25rem;padding-right:2rem}.history-card-header p{color:#cbd5e1;font-size:.95rem;margin:0}.history-card-meta{border-top:1px solid #ffffff1f;color:#cbd5e1;font-size:.9rem;margin-top:.75rem;padding-top:.75rem}.history-card-meta p{margin:.25rem 0}.history-card-tags{display:flex;flex-wrap:wrap;gap:.45rem;margin-top:.9rem}.history-tag{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:.78rem;font-weight:700;gap:.3rem;padding:.35rem .6rem}.history-tag svg{display:block}.history-tag-audio{background:#3b82f624;border-color:#3b82f659;color:#bfdbfe}.history-tag-soap{background:#10b98124;border-color:#10b98159;color:#bbf7d0}.history-tag-ai{background:#ec48991f;border-color:#ec489952;color:#fbcfe8}.history-tag-pii{background:#ef44441f;border-color:#ef444447;color:#fecdd3}.history-card-preview{background:#ffffff0a;border:1px solid #ffffff14;border-radius:12px;color:#e2e8f0;font-size:.92rem;margin-top:1rem;padding:.75rem}.history-card-preview p{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;line-height:1.5;margin:.45rem 0 0;overflow:hidden;text-overflow:ellipsis}@media (max-width:768px){.history-modal-overlay{padding:1rem}.history-modal{max-height:92vh}.history-modal-header{align-items:flex-start;flex-direction:column}.history-header-left{justify-content:space-between;width:100%}.history-filter-actions{align-items:stretch;flex-direction:column}.history-results-chip{text-align:center;width:100%}.history-grid{grid-template-columns:1fr}.history-filter-toggle{flex:0 0 auto}}.landing-page{background:radial-gradient(140% 100% at 10% 10%,#6366f129,#0000 45%),radial-gradient(120% 120% at 90% 20%,#22d3ee1f,#0000 40%),linear-gradient(145deg,#0b1224,#0c1e38 35%,#0f1f3d);color:#e2e8f0;font-family:Space Grotesk,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;min-height:100vh}.landing-page *,.landing-page :after,.landing-page :before{box-sizing:border-box}.lp-container{margin:0 auto;padding:0 1.25rem;width:min(1200px,90vw)}.lp-section{padding:5rem 0}.lp-fade-in{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}.lp-fade-in-visible{opacity:1;transform:translateY(0)}.lp-navbar{background:#0000;left:0;padding:1.5rem 0;position:fixed;right:0;top:0;transition:all .8s ease;z-index:1000}.lp-navbar-scrolled{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(135deg,#0f172ae6,#0c1f38f2);box-shadow:0 14px 32px #00000047;padding:1rem 0}.lp-nav-content{align-items:center;display:flex;justify-content:space-between}.lp-logo{font-size:1.5rem;text-shadow:0 2px 8px #0003}.lp-login-button,.lp-logo{color:#e2e8f0;font-weight:700;transition:all .3s ease}.lp-login-button{background:#ffffff14;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 10px 26px #00000040;cursor:pointer;font-size:1rem;padding:.625rem 1.5rem}.lp-login-button:hover{background:#ffffff1f;box-shadow:0 12px 30px #00000052;transform:translateY(-2px)}.lp-login-button:active{transform:translateY(0)}.lp-hero-section{background:radial-gradient(circle at top right,#6366f159,#0c1f38f2);color:#f8fafc;overflow:hidden;padding:10rem 0 5rem;position:relative}.lp-hero-section:after{background:url("data:image/svg+xml;charset=utf-8,%3Csvg width='160' height='160' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill='rgba(255,255,255,0.05)' d='M0 0h1v1H0z'/%3E%3C/svg%3E");content:"";inset:0;opacity:.5;pointer-events:none;position:absolute}.lp-hero-grid{grid-gap:2.5rem;align-items:start;display:grid;gap:2.5rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));position:relative;z-index:1}.lp-hero-copy{max-width:540px}.lp-hero-copy h1{color:#f8fafc;font-size:clamp(2.8rem,5vw,3.8rem);line-height:1.1;margin:.75rem 0 1.5rem}.lp-hero-copy p{color:#cbd5e1;font-size:1.1rem;margin-bottom:2rem;max-width:36rem}.lp-hero-copy .lp-eyebrow{color:#ffffffb8;font-size:.85rem;letter-spacing:.3em;text-transform:uppercase}.lp-hero-actions{display:flex;flex-wrap:wrap;gap:1rem}.lp-cta-button{align-items:center;background-clip:padding-box;border:1px solid #0000;border-radius:12px;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:700;gap:.6rem;justify-content:center;padding:.95rem 1.8rem;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.lp-cta-button.lp-primary{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);background-clip:initial;border:none;box-shadow:0 14px 32px #14b8a659,0 0 0 1px #ffffff0f;color:#fff}.lp-cta-button.lp-ghost{background:#ffffff14;border:1px solid #ffffff59;color:#fff}.lp-cta-button:hover{transform:translateY(-2px)}.lp-hero-metrics{display:flex;flex-wrap:wrap;gap:1.5rem;margin-top:2.5rem}.lp-hero-metrics span{display:block;font-size:2rem;font-weight:700}.lp-hero-metrics div{min-width:130px}.lp-hero-video{animation:lp-gentle-float 6s ease-in-out infinite;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#0f172a73;border:1px solid #ffffff26;border-radius:32px;box-shadow:0 25px 60px #0f172a59;margin-left:auto;max-width:540px;padding:1rem;transition:transform .4s ease,box-shadow .4s ease}.lp-hero-video:hover{animation-play-state:paused;box-shadow:0 35px 80px #0f172a80;transform:translateY(-12px) translateX(4px)}@keyframes lp-gentle-float{0%,to{transform:translateY(0) translateX(0)}}.lp-hero-video-frame{background:linear-gradient(135deg,#94a3ff33,#3b82f614);border:1px solid #ffffff2e;border-radius:24px;overflow:hidden;position:relative}.lp-hero-video-player{aspect-ratio:16/9;background:#0b1120;border-radius:20px;display:block;height:100%;object-fit:contain;width:100%}.lp-hero-video-badge{background:#ffffffe6;border-radius:999px;box-shadow:0 8px 25px #00000026;color:#0b1224;font-size:.95rem;font-weight:700;left:14px;padding:.5rem .95rem;position:absolute;top:14px}.lp-hero-pipeline-card{background:#ffffff0f;border:1px solid #ffffff29;border-radius:18px;box-shadow:0 18px 40px #0f172a40;color:#e2e8f0;margin-top:1rem;padding:1rem 1.25rem}.lp-hero-pipeline-header{align-items:center;color:#fff;display:flex;flex-wrap:wrap;font-size:1rem;font-weight:700;gap:1rem;justify-content:space-between}.lp-hero-pipeline-title{font-size:1.05rem}.lp-hero-pipeline-status{color:#e0e7ff;font-size:.95rem;opacity:.9}.lp-hero-pipeline-card ul{grid-gap:.65rem;display:grid;gap:.65rem;list-style:none;margin:0;padding:.5rem 0 0}.lp-hero-pipeline-card li{grid-gap:.2rem;display:grid;gap:.2rem}.lp-hero-stage{background:linear-gradient(145deg,#ffffff0f,#ffffff08);border:1px solid #ffffff1f;border-radius:14px;box-shadow:inset 0 1px 0 #ffffff0f;padding:.9rem 1rem;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease}.lp-hero-stage:hover{background:linear-gradient(145deg,#ffffff17,#ffffff0a);border-color:#fff3;box-shadow:0 12px 24px #0f172a40;transform:translateX(6px)}.lp-hero-pipeline-card strong{color:#fff;font-size:.98rem;font-weight:700}.lp-hero-pipeline-card span{color:#e2e8f0d9;font-size:.92rem;line-height:1.45}.lp-trust-panel{background:#0000;border-bottom:1px solid #ffffff14;padding:2.5rem 0}.lp-trust-grid{align-items:center;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;text-align:center}.lp-trust-logos{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));width:100%}.lp-trust-logos span{background:#ffffff0a;border:1px solid #ffffff24;border-radius:14px;box-shadow:0 10px 26px #00000038;color:#cbd5e1;font-size:.85rem;letter-spacing:.2em;padding:.85rem .5rem;text-align:center;text-transform:uppercase}.lp-video-section{background:#0000;padding:5rem 0}.lp-video-container{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0a;border:1px solid #ffffff24;border-radius:24px;box-shadow:0 25px 50px #00000047;margin:0 auto;overflow:hidden;width:100%}.lp-demo-video{background:#000;display:block;height:auto;min-height:500px;object-fit:cover;width:100%}.lp-capabilities-section{background:#0000}.lp-section-header{margin-bottom:3.5rem;text-align:center}.lp-section-title{color:#f8fafc;font-size:clamp(2.2rem,4vw,3rem);margin-bottom:.5rem}.lp-section-description{color:#cbd5e1;margin:0 auto;max-width:580px}.lp-capabilities-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.lp-capability-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:24px;box-shadow:0 18px 36px #00000047;color:#e2e8f0;padding:2rem;transition:transform .2s ease,box-shadow .2s ease}.lp-capability-card:hover{box-shadow:0 25px 45px #00000052;transform:translateY(-6px)}.lp-capability-icon{background:#ffffff14;border-radius:16px;color:#22d3ee;display:grid;height:56px;margin-bottom:1.25rem;place-items:center;width:56px}.lp-capability-card h3{margin-bottom:.5rem}.lp-capability-card p{color:#cbd5e1}.lp-workflow-section{background:#0000}.lp-workflow-card{background:#0b1120;border-radius:48px;box-shadow:0 35px 70px #02061780;color:#fff;padding:3.5rem}.lp-workflow-card .lp-section-header{margin-bottom:3rem}.lp-workflow-timeline{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));position:relative}.lp-workflow-step{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0d;border:1px solid #ffffff24;border-radius:24px;box-shadow:0 18px 36px #00000047;min-height:220px;padding:2rem}.lp-step-index{background:#ffffff26;border-radius:14px;display:grid;font-weight:600;height:48px;margin-bottom:1.5rem;place-items:center;width:48px}.lp-workflow-step h3{margin-bottom:.5rem}.lp-workflow-step p{color:#fffc}.lp-compliance-section{background:#0000;padding-bottom:6rem}.lp-compliance-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.lp-compliance-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:24px;box-shadow:0 18px 36px #00000047;color:#e2e8f0;padding:1.85rem}.lp-compliance-card h3{margin-bottom:.25rem}.lp-compliance-card p{color:#cbd5e1}.lp-cta-section{background:linear-gradient(135deg,#22d3ee2e,#6366f147);border:1px solid #ffffff24;border-radius:48px;box-shadow:0 30px 60px #00000059;color:#f8fafc;margin:0 auto 4rem;padding:4rem 2rem;text-align:center;width:min(1040px,90vw)}.lp-cta-content{align-items:center;display:flex;flex-direction:column;justify-content:center}.lp-cta-content h2{font-size:clamp(2.2rem,4vw,3rem);margin-bottom:1rem}.lp-cta-content p{color:#ffffffbf;margin-bottom:2rem;max-width:600px}.lp-cta-content .lp-hero-actions{justify-content:center}.lp-footer{background:#020617;color:#ffffffb3;padding:2rem 0;text-align:center}.lp-footer p{font-size:.9rem;margin:.25rem 0}.lp-footer-tagline{color:#94a3b8e6;font-size:.85rem}@media (max-width:960px){.lp-hero-actions{align-items:stretch;flex-direction:column}.lp-hero-metrics{justify-content:space-between}.lp-trust-grid{flex-direction:column}.lp-section{padding:4rem 0}.lp-workflow-timeline{grid-template-columns:1fr}.lp-workflow-card{padding:2.5rem}.lp-hero-video{margin-left:auto;margin-right:auto;max-width:100%}.lp-hero-grid{grid-template-columns:1fr}.lp-compliance-section{padding-bottom:4rem}.lp-compliance-grid{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.lp-cta-section{border-radius:40px;padding:3.5rem 2rem;width:min(1040px,92vw)}.lp-cta-content h2{font-size:clamp(1.8rem,4vw,2.5rem)}.lp-cta-content p{font-size:1rem;margin-bottom:1.75rem}}@media (max-width:640px){.lp-hero-pipeline{border-radius:24px;padding:1.5rem}.lp-hero-metrics span{font-size:1.5rem}.lp-trust-logos span{letter-spacing:.1em}.lp-capability-card,.lp-compliance-card,.lp-workflow-step{padding:1.5rem}.lp-workflow-card{border-radius:32px;padding:2rem}.lp-compliance-section{padding-bottom:3rem}.lp-compliance-grid{gap:1rem;grid-template-columns:1fr}.lp-compliance-card{border-radius:20px;padding:1.35rem}.lp-compliance-card h3{font-size:1.05rem}.lp-compliance-card p{font-size:.9rem}.lp-cta-section{border-radius:32px;padding:2.5rem 1.5rem;width:95vw}.lp-cta-content h2{font-size:1.75rem;margin-bottom:.75rem}.lp-cta-content p{font-size:.95rem;margin-bottom:1.5rem}.lp-cta-content .lp-hero-actions{gap:.75rem}.lp-cta-content .lp-cta-button{font-size:.95rem;padding:.85rem 1.5rem}.lp-hero-section{padding:8rem 0 4rem}.lp-hero-copy h1{font-size:2rem}.lp-hero-copy p{font-size:1rem}}.demo-container{align-items:center;background:radial-gradient(140% 100% at 10% 10%,#6366f129,#0000 45%),radial-gradient(120% 120% at 90% 20%,#22d3ee1f,#0000 40%),linear-gradient(145deg,#0b1224,#0c1e38 35%,#0f1f3d);color:#e2e8f0;display:flex;flex-direction:column;min-height:100vh;padding:80px 20px 40px;position:relative}.demo-top-bar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0f;border:1px solid #ffffff24;border-radius:14px;box-shadow:0 12px 30px #00000047;display:flex;gap:.6rem;padding:.4rem .6rem;position:absolute;right:24px;top:24px;z-index:100}.home-btn{background:#ffffff14;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 10px 30px #00000040;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 16px;position:relative;transition:all .25s ease}.home-btn:before{background:linear-gradient(135deg,#ffffff14,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.home-btn:hover:before{opacity:1}.home-btn:hover{border-color:#ffffff40;box-shadow:0 14px 30px #00000059;transform:translateY(-2px)}.home-btn:active{transform:translateY(-1px)}.history-toggle-btn{background:#ffffff14;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 10px 30px #00000040;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 16px;position:relative;transition:all .25s ease}.history-toggle-btn:before{background:linear-gradient(135deg,#ffffff14,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.history-toggle-btn:hover:before{opacity:1}.history-toggle-btn:hover{border-color:#ffffff40;box-shadow:0 14px 30px #00000059;transform:translateY(-2px)}.history-toggle-btn:active{transform:translateY(-1px)}.patient-portal-btn{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:12px;box-shadow:0 12px 32px #14b8a659;color:#fff;cursor:pointer;font-size:14px;font-weight:800;letter-spacing:.01em;overflow:hidden;padding:10px 18px;position:relative;transition:all .25s ease}.patient-portal-btn:before{background:linear-gradient(135deg,#ffffff24,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.patient-portal-btn:hover:before{opacity:1}.patient-portal-btn:hover{box-shadow:0 16px 38px #14b8a673;transform:translateY(-2px)}.patient-portal-btn:active{transform:translateY(-1px)}.history-sidebar-overlay{background-color:#00000080;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:1001}.history-sidebar{animation:slideInRight .3s ease-out;background:#0f172ae6;border-left:1px solid #ffffff24;box-shadow:-4px 0 24px #0000004d;display:flex;flex-direction:column;max-width:90vw;width:400px}@keyframes slideInRight{0%{transform:translateX(100%)}to{transform:translateX(0)}}.history-header{align-items:center;background:linear-gradient(135deg,#6366f159,#22d3ee26);border-bottom:1px solid #ffffff24;color:#f8fafc;display:flex;justify-content:space-between;padding:20px}.history-header h3{font-size:1.3rem;margin:0}.history-close{align-items:center;background:none;border:none;color:#f8fafc;cursor:pointer;display:flex;font-size:32px;height:32px;justify-content:center;padding:0;transition:transform .2s;width:32px}.history-close:hover{transform:scale(1.2)}.history-list{flex:1 1;overflow-y:auto;padding:10px}.history-empty{color:#cbd5e1;font-size:1rem;padding:40px 20px;text-align:center}.history-item{background:#ffffff0f;border:1px solid #ffffff24;border-radius:12px;color:#e2e8f0;cursor:pointer;margin-bottom:10px;padding:15px;transition:all .2s}.history-item:hover{border-color:#fff3;box-shadow:0 8px 18px #00000040;transform:translateX(-5px)}.history-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.history-item-header strong{color:#f8fafc;font-size:1rem}.history-item-date{color:#a5b4fc;font-size:.85rem;font-weight:600}.history-item-details{color:#cbd5e1;font-size:.9rem;margin-bottom:4px}.history-item-time{color:#94a3b8;font-size:.8rem}.demo-header{color:#e2e8f0;margin-bottom:32px;max-width:1100px;padding:0 20px;text-align:center;width:100%}.demo-header h1{color:#f8fafc;font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;line-height:1.2;margin-bottom:10px}.demo-header p{color:#cbd5e1;font-size:clamp(.95rem,3vw,1.1rem)}.demo-form{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(160deg,#0f172a99,#6366f11f 35%,#22d3ee14);border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 36px #00000057;color:#e2e8f0;max-width:1200px;padding:32px;width:100%}.form-group{margin-bottom:24px}.form-group label{color:#e2e8f0;display:block;font-size:14px;font-weight:700;margin-bottom:8px}.form-group input[type=date],.form-group input[type=text]{background:#ffffff0f;border:1px solid #ffffff2e;border-radius:12px;box-sizing:border-box;color:#e2e8f0;font-size:16px;padding:14px;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.form-group input[type=date]:focus,.form-group input[type=text]:focus{border-color:#63b3ed;box-shadow:0 0 0 3px #63b3ed40;outline:none}.patient-select-wrapper{position:relative}.patient-select-wrapper input{cursor:pointer}.patient-dropdown{background:#0f172acc;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 12px 30px #0000004d;left:0;margin-top:4px;position:absolute;right:0;top:100%;z-index:10}.patient-option{color:#e2e8f0;cursor:pointer;padding:12px;transition:background-color .2s}.patient-option:hover{background-color:#ffffff0f}.patient-name{color:#f8fafc;font-weight:600;margin-bottom:4px}.patient-details{color:#cbd5e1;font-size:12px}.audio-file-display{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0f;border:1px solid #ffffff1f;border-radius:16px;box-shadow:0 4px 12px #0000000f;padding:24px}.audio-file-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.audio-file-name{color:#e2e8f0;font-size:15px;font-weight:600}.audio-file-badge{background:linear-gradient(135deg,#22d3ee,#6366f1);border-radius:12px;box-shadow:0 2px 8px #2563eb33;color:#fff;font-size:12px;font-weight:600;padding:6px 14px}.audio-player{background:#0000;height:48px;outline:none;width:100%}.generate-btn{background:linear-gradient(135deg,#0f9b8e,#14b8a6 50%,#a7f3d0);border:none;border-radius:14px;box-shadow:0 14px 32px #14b8a659;color:#fff;cursor:pointer;font-size:16px;font-weight:800;margin-top:10px;overflow:hidden;padding:14px;position:relative;transition:all .25s ease;width:100%}.generate-btn:before{background:linear-gradient(135deg,#ffffff1a,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.generate-btn:hover:not(:disabled):before{opacity:1}.generate-btn:hover:not(:disabled){box-shadow:0 16px 40px #14b8a680;transform:translateY(-2px)}.generate-btn:active:not(:disabled){transform:translateY(-1px)}.generate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.stopwatch-display{background:linear-gradient(135deg,#22d3ee1f,#6366f11f);border:1px solid #ffffff29;border-radius:14px;box-shadow:0 12px 28px #00000040;color:#e2e8f0;margin-top:20px;padding:20px;text-align:center}.stopwatch-icon{color:#cbd5e1;font-size:1rem;letter-spacing:.02em;margin-bottom:6px}.stopwatch-time{color:#22d3ee;font-size:2.5rem;font-weight:700;margin-bottom:5px}.stopwatch-label{color:#cbd5e1;font-size:14px;font-weight:600}.patient-actions{display:flex;gap:12px;margin-bottom:20px}.edit-patient-btn{background:#ffffff14;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 10px 24px #00000040;color:#e2e8f0;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;overflow:hidden;padding:10px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.edit-patient-btn:before{background:linear-gradient(135deg,#2563eb1a,#2563eb00);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.edit-patient-btn:hover:before{opacity:1}.edit-patient-btn:hover{border-color:#ffffff3d;box-shadow:0 16px 30px #0000004d;transform:translateY(-2px)}.edit-patient-btn:active{transform:translateY(-1px)}.remove-patient-btn{background:#ef44441f;border:1px solid #ef444466;border-radius:12px;box-shadow:0 10px 24px #00000040;color:#fecdd3;cursor:pointer;flex:1 1;font-size:14px;font-weight:700;overflow:hidden;padding:10px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.remove-patient-btn:before{background:linear-gradient(135deg,#e74c3c1a,#e74c3c00);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.remove-patient-btn:hover:before{opacity:1}.remove-patient-btn:hover{background:#e74c3c;box-shadow:0 16px 36px #e74c3c73;color:#fff;transform:translateY(-2px)}.remove-patient-btn:active{transform:translateY(-1px)}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{color:#333;font-size:1.5rem;margin:0}.modal-close{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:color .2s;width:32px}.modal-close:hover{color:#333}.modal-body{padding:24px}.modal-form-group{margin-bottom:20px}.modal-form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.modal-form-group input{border:2px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-size:16px;padding:12px;transition:border-color .3s;width:100%}.modal-form-group input:focus{border-color:#2563eb;outline:none}.modal-footer{border-top:1px solid #e0e0e0;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.modal-btn{border:none;border-radius:16px;box-shadow:0 10px 30px #0003;cursor:pointer;font-size:14px;font-weight:600;overflow:hidden;padding:10px 24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.modal-btn:before{content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.modal-btn:hover:before{opacity:1}.modal-btn-cancel{background:#f5f5f5;color:#666}.modal-btn-cancel:before{background:linear-gradient(135deg,#0000000d,#0000)}.modal-btn-cancel:hover{background:#e0e0e0;box-shadow:0 15px 40px #00000026;transform:translateY(-3px)}.modal-btn-cancel:active{transform:translateY(-1px)}.modal-btn-save{background:linear-gradient(135deg,#2563eb,#0ea5e9);color:#fff}.modal-btn-save:before{background:linear-gradient(135deg,#ffffff1a,#fff0)}.modal-btn-save:hover{box-shadow:0 15px 40px #2563eb66;transform:translateY(-3px)}.modal-btn-save:active{transform:translateY(-1px)}.patient-portal-container{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:linear-gradient(160deg,#0f172a99,#6366f11f 35%,#22d3ee14);border:1px solid #ffffff1f;border-radius:18px;box-shadow:0 18px 36px #0000004d;color:#e2e8f0;max-width:900px;padding:60px 40px;text-align:center;width:100%}.patient-portal-content h2{color:#f8fafc;font-size:2rem;margin-bottom:10px}.patient-portal-content p{color:#cbd5e1;font-size:1.1rem;margin-bottom:40px}.claim-records-btn{background:linear-gradient(135deg,#22d3ee,#6366f1 50%,#a855f7);border:none;border-radius:14px;box-shadow:0 14px 32px #6366f173;color:#fff;cursor:pointer;font-size:18px;font-weight:800;overflow:hidden;padding:16px 40px;position:relative;transition:all .25s ease}.claim-records-btn:before{background:linear-gradient(135deg,#ffffff1a,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.claim-records-btn:hover:before{opacity:1}.claim-records-btn:hover{box-shadow:0 16px 38px #6366f18c;transform:translateY(-2px)}.claim-records-btn:active{transform:translateY(-1px)}.patient-records-view{text-align:left;width:100%}.patient-records-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.patient-records-header h2{color:#f8fafc;font-size:1.8rem;margin:0}.back-to-portal-btn{background:#ffffff14;border:1px solid #ffffff2e;border-radius:12px;box-shadow:0 10px 24px #00000040;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 20px;position:relative;transition:all .25s cubic-bezier(.4,0,.2,1)}.back-to-portal-btn:before{background:linear-gradient(135deg,#2563eb1a,#2563eb00);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.back-to-portal-btn:hover:before{opacity:1}.back-to-portal-btn:hover{border-color:#2563eb;box-shadow:0 15px 40px #2563eb4d;transform:translateX(-3px)}.back-to-portal-btn:active{transform:translateX(-1px)}.no-records{color:#cbd5e1;padding:60px 20px;text-align:center}.no-records p{font-size:1.2rem}.patient-records-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.patient-record-card{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:linear-gradient(160deg,#0f172a99,#6366f11f 35%,#22d3ee14);border:1px solid #ffffff24;border-radius:16px;box-shadow:0 16px 32px #0000004d;color:#e2e8f0;padding:25px;transition:all .3s}.patient-record-card:hover{border-color:#ffffff38;box-shadow:0 20px 36px #00000059}.patient-record-header{align-items:center;border-bottom:1px solid #ffffff24;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.patient-record-header h3{color:#f8fafc;font-size:1.3rem;margin:0}.patient-record-time{color:#cbd5e1;font-size:.9rem}.patient-record-sections{display:flex;flex-direction:column;gap:15px;margin-bottom:15px}.patient-record-section{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:12px;padding:15px}.patient-record-section h4{color:#c7d2fe;font-size:1.1rem;font-weight:700;margin:0 0 10px}.patient-record-section p{color:#e2e8f0;line-height:1.6;margin:0;white-space:pre-wrap}.patient-record-section ul{margin:0;padding-left:20px}.patient-record-section li{color:#e2e8f0;line-height:1.6;margin-bottom:8px}.patient-education-section{border-left-color:#27ae60}.patient-education-section h4{color:#27ae60}.follow-up-section{border-left-color:#e67e22}.follow-up-section h4{color:#e67e22}.error-message{background-color:#ef44441a;border:1px solid #ef444466;border-radius:12px;color:#fecdd3;font-weight:700;margin-top:20px;padding:16px}.soap-results{background:linear-gradient(160deg,#0f172a99,#6366f11f 35%,#22d3ee14);border:1px solid #ffffff24;border-radius:16px;box-shadow:0 18px 36px #00000052;color:#e2e8f0;margin-top:30px;padding:24px}.soap-results-header{align-items:center;border-bottom:1px solid #ffffff1f;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.soap-results h3{color:#f8fafc;font-size:1.5rem;margin:0 0 5px}.generation-time{color:#cbd5e1;font-size:.9rem;margin:0}.soap-action-buttons{display:flex;gap:10px}.soap-action-btn{background:#ffffff0f;border:1px solid #ffffff24;border-radius:12px;box-shadow:0 10px 24px #00000040;color:#e2e8f0;cursor:pointer;font-size:14px;font-weight:700;overflow:hidden;padding:10px 20px;position:relative;transition:all .25s ease;white-space:nowrap}.soap-action-btn:before{background:linear-gradient(135deg,#ffffff1a,#fff0);content:"";height:100%;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.soap-action-btn:hover:not(:disabled):before{opacity:1}.soap-action-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.edit-btn{background:linear-gradient(135deg,#fb923c,#f97316);color:#fff}.edit-btn:hover:not(:disabled){background:#dd6b20;box-shadow:0 15px 40px #ed893666;transform:translateY(-3px)}.edit-btn:active:not(:disabled){transform:translateY(-1px)}.copy-btn{background:linear-gradient(135deg,#22d3ee,#6366f1);color:#fff}.copy-btn:hover:not(:disabled){background:#3182ce;box-shadow:0 15px 40px #4299e166;transform:translateY(-3px)}.copy-btn:active:not(:disabled){transform:translateY(-1px)}.save-btn{background:linear-gradient(135deg,#22d3ee,#6366f1 50%,#a855f7);color:#fff}.save-btn:hover:not(:disabled){background:#805ad5;box-shadow:0 15px 40px #9f7aea66;transform:translateY(-3px)}.save-btn:active:not(:disabled){transform:translateY(-1px)}.saved-btn{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.saved-btn:hover:not(:disabled){background:#38a169;box-shadow:0 15px 40px #48bb7866;transform:translateY(-3px)}.saved-btn:active:not(:disabled){transform:translateY(-1px)}.cancel-btn{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff}.cancel-btn:hover:not(:disabled){background:#c53030;box-shadow:0 15px 40px #e53e3e66;transform:translateY(-3px)}.cancel-btn:active:not(:disabled){transform:translateY(-1px)}.soap-section{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:12px;box-shadow:0 6px 16px #0003;margin-bottom:16px;padding:20px}.soap-section h4{color:#c7d2fe;font-size:1.2rem;font-weight:700;margin-bottom:12px}.soap-content{white-space:pre-wrap}.soap-content,.soap-edit-textarea{color:#e2e8f0;font-size:.95rem;line-height:1.6}.soap-edit-textarea{background:#ffffff0f;border:1px solid #ffffff2e;border-radius:10px;box-sizing:border-box;font-family:inherit;min-height:100px;padding:12px;resize:vertical;width:100%}.soap-edit-textarea:focus{border-color:#63b3ed;box-shadow:0 0 0 3px #63b3ed40;outline:none}@media (max-width:768px){.demo-container{padding:100px 15px 30px}.demo-top-bar{flex-wrap:wrap;gap:8px;right:15px;top:15px}.history-toggle-btn,.home-btn,.patient-portal-btn{font-size:12px;padding:8px 12px}.demo-header{margin-bottom:30px;padding:0 15px}.demo-form{padding:25px 20px}}@media (max-width:480px){.demo-container{padding:120px 10px 20px}.demo-top-bar{justify-content:center;left:10px;right:10px;top:10px}.history-toggle-btn,.home-btn,.patient-portal-btn{flex:1 1;font-size:11px;min-width:90px;padding:8px 10px}.demo-header h1{font-size:1.5rem}.demo-header p{font-size:.9rem}}
/*# sourceMappingURL=main.0eb34ff9.css.map*/