@import"https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700&family=Playfair+Display:ital,wght@0,400;0,600;1,400&display=swap";:root{--color-bg-off-white: #F9F9F7;--color-bg-warm-beige: #FDFCF8;--color-accent-mint: #E0EFEA;--color-accent-teal: #A4C3B2;--color-accent-lavender: #E0DFEF;--color-text-primary: #1A1A1A;--color-text-secondary: #555555;--color-white: #FFFFFF;--color-primary-action: #2C5F4D;--color-primary-action-hover: #1F4538;--font-serif: "Playfair Display", serif;--font-sans: "Lato", sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.5rem;--text-2xl: 2rem;--text-3xl: 3rem;--text-4xl: 4rem;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 2rem;--spacing-lg: 4rem;--spacing-xl: 8rem;--radius-sm: 8px;--radius-md: 16px;--radius-lg: 32px;--radius-full: 9999px;--shadow-sm: 0 4px 10px rgba(0, 0, 0, .03);--shadow-md: 0 10px 20px rgba(0, 0, 0, .04);--shadow-lg: 0 20px 40px rgba(0, 0, 0, .05);--transition-fast: .2s ease;--transition-smooth: .4s cubic-bezier(.4, 0, .2, 1)}@media(max-width:768px){:root{--spacing-xs: .25rem;--spacing-sm: .75rem;--spacing-md: 1.5rem;--spacing-lg: 2.5rem;--spacing-xl: 4rem;--text-4xl: 2.5rem;--text-3xl: 2rem;--text-2xl: 1.5rem}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--color-bg-off-white);color:var(--color-text-primary);line-height:1.7;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,h5,h6{font-family:var(--font-serif);font-weight:600;line-height:1.2;color:var(--color-text-primary)}p{color:var(--color-text-secondary)}button{cursor:pointer;border:none;font-family:inherit}a{text-decoration:none;color:inherit;transition:var(--transition-fast)}img{max-width:100%;display:block}.container{width:90%;max-width:1280px;margin:0 auto;padding:0 var(--spacing-sm)}.section{padding:var(--spacing-xl) 0}.scroll-progress{position:fixed;top:0;left:0;width:0%;height:3px;background:linear-gradient(90deg,var(--color-accent-mint),var(--color-accent-teal),var(--color-primary-action));z-index:9998}.gradient-mesh{background:radial-gradient(at 40% 20%,rgba(157,227,218,.3) 0px,transparent 50%),radial-gradient(at 80% 0%,rgba(200,182,255,.2) 0px,transparent 50%),radial-gradient(at 0% 50%,rgba(157,227,218,.2) 0px,transparent 50%),radial-gradient(at 80% 50%,rgba(255,244,232,.4) 0px,transparent 50%),linear-gradient(180deg,var(--color-bg-off-white) 0%,var(--color-bg-warm-beige) 100%)}.hover-glow:hover{box-shadow:0 0 30px #9de3da4d}.stagger-in{opacity:0;transform:translateY(20px);animation:staggerIn .6s forwards}@keyframes staggerIn{to{opacity:1;transform:translateY(0)}}.card{background-color:#fff;border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:transform .3s ease,box-shadow .3s ease;position:relative}.card--hover:hover{transform:translateY(-8px);box-shadow:0 20px 40px #0000001f}.card--glass{background:#ffffffd9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.5)}.card--glow{transition:transform .3s ease,box-shadow .3s ease}.card--glow:hover{box-shadow:0 20px 40px #0000001a,0 0 40px #9de3da33}.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 32px;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);border:none;position:relative;overflow:hidden;font-family:inherit}.btn__text{position:relative;z-index:1}.btn--primary{background:linear-gradient(135deg,var(--color-primary-action) 0%,#2a4a40 100%);color:#fff;box-shadow:0 4px 15px #2d37324d}.btn--primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #2d373266}.btn--primary:active{transform:translateY(0)}.btn--outline{background:transparent;color:var(--color-primary-action);border:2px solid var(--color-primary-action);position:relative}.btn--outline:before{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:var(--color-primary-action);transform:scaleX(0);transform-origin:right;transition:transform .4s cubic-bezier(.175,.885,.32,1.275);z-index:0}.btn--outline:hover:before{transform:scaleX(1);transform-origin:left}.btn--outline:hover,.btn--outline:hover .btn__text{color:#fff}.btn__ripple{position:absolute;width:20px;height:20px;background:#fff6;border-radius:50%;transform:translate(-50%,-50%) scale(0);animation:ripple .6s ease-out forwards;pointer-events:none}@keyframes ripple{to{transform:translate(-50%,-50%) scale(15);opacity:0}}.btn--secondary{background:#fff;color:var(--color-primary-action);border:2px solid transparent;background-clip:padding-box;position:relative}.btn--secondary:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;border-radius:var(--radius-md);padding:2px;background:linear-gradient(135deg,var(--color-accent-mint),var(--color-accent-teal),var(--color-accent-lavender));background-size:200% 200%;animation:gradientRotate 3s linear infinite;-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude}@keyframes gradientRotate{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.login-page{min-height:100vh;display:flex;padding:0;overflow:hidden}.branding-section{display:none;flex:1;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-xl);position:relative;background:linear-gradient(135deg,#2c5f4d08,#2c5f4d14)}@media(min-width:900px){.branding-section{display:flex}}.brand-content{text-align:center}.brand-name{font-size:3rem;font-weight:700;color:var(--color-primary-action);margin:0;letter-spacing:-1px}.brand-tagline{font-size:var(--text-lg);color:var(--color-text-secondary);margin:8px 0 0}.brand-values{list-style:none;padding:0;margin:40px 0 0;text-align:left;display:inline-block}.brand-values li{display:flex;align-items:center;gap:12px;color:var(--color-text-secondary);font-size:var(--text-lg);padding:12px 0}.brand-values li svg{flex-shrink:0;color:var(--color-primary-action);opacity:.7}.orbital-ring{position:absolute;width:100%;height:100%;animation:rotateOrbit 30s linear infinite}@keyframes rotateOrbit{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.orbital-item{position:absolute;width:70px;height:70px;top:50%;left:50%;margin-left:-35px;margin-top:-35px;transform:rotate(calc(120deg * var(--i))) translate(170px);animation:counterRotate 30s linear infinite}@keyframes counterRotate{0%{transform:rotate(calc(120deg * var(--i))) translate(170px) rotate(0)}to{transform:rotate(calc(120deg * var(--i) + 360deg)) translate(170px) rotate(-360deg)}}.orbital-icon{width:70px;height:70px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #00000014;cursor:pointer;position:relative;transition:transform .3s ease,box-shadow .3s ease;border:2px solid rgba(44,95,77,.1)}.orbital-icon:hover{transform:scale(1.15);box-shadow:0 8px 30px #2c5f4d26}.icon-svg{display:flex;align-items:center;justify-content:center}.icon-svg svg{width:28px;height:28px}.orbital-tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);background:var(--color-primary-action);color:#fff;padding:10px 14px;border-radius:var(--radius-sm);white-space:nowrap;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:100;text-align:center}.orbital-tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-6px;border:6px solid transparent;border-top-color:var(--color-primary-action)}.orbital-tooltip strong{display:block;font-size:var(--text-sm);margin-bottom:2px}.orbital-tooltip span{font-size:11px;opacity:.9}.orbital-icon:hover .orbital-tooltip{opacity:1;visibility:visible}.values-strip{display:flex;flex-wrap:wrap;gap:12px;margin-top:var(--spacing-xl);justify-content:center}.value-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--color-text-secondary);box-shadow:0 2px 10px #0000000a;border:1px solid rgba(0,0,0,.05)}.chip-icon{display:flex;align-items:center;justify-content:center}.chip-icon svg{width:16px;height:16px}.login-section{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:var(--spacing-lg);max-width:500px}@media(min-width:900px){.login-section{max-width:none}}.mobile-brand{text-align:center;margin-bottom:var(--spacing-lg)}.mobile-brand h1{font-size:var(--text-3xl);color:var(--color-primary-action);margin:0}.mobile-brand p{color:var(--color-text-secondary);margin:4px 0 0;font-size:var(--text-sm)}@media(min-width:900px){.mobile-brand{display:none}}.login-card{width:100%;max-width:400px;text-align:center}.login-card h2{margin-bottom:var(--spacing-xs);font-size:var(--text-2xl)}.login-card .subtitle{margin-bottom:var(--spacing-md);color:var(--color-text-secondary)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.form-group{display:flex;flex-direction:column;text-align:left}.form-group label{font-size:var(--text-sm);font-weight:600;margin-bottom:6px;color:var(--color-text-primary)}.form-group input{padding:14px 16px;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background:#fff}.form-group input:focus{outline:none;border-color:var(--color-primary-action);box-shadow:0 0 0 3px #2c5f4d1a}.form-group input::placeholder{color:var(--color-text-secondary);opacity:.6}.login-form .btn{margin-top:var(--spacing-xs);width:100%}.login-error{background:#dc35451a;color:#dc3545;padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--text-sm);margin-bottom:var(--spacing-sm)}.login-footer{margin-top:var(--spacing-md);font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center}@media(max-width:899px){.login-page{justify-content:center;padding:var(--spacing-md)}.login-section{width:100%;max-width:420px;padding:0}}.patients-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.header-actions-right{display:flex;gap:var(--spacing-sm);align-items:center;flex:1;justify-content:flex-end}.tabs-container{display:flex;gap:4px;background:#f1f5f9;padding:4px;border-radius:999px}.tab-pill{display:flex;align-items:center;gap:8px;padding:8px 16px;border-radius:999px;border:none;background:transparent;color:#64748b;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s}.tab-pill:hover{color:#334155;background:#ffffff80}.tab-pill.active{background:#fff;color:var(--color-primary, #1B4B43);box-shadow:0 1px 3px #0000001a;font-weight:600}.search-box{display:flex;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;padding:0 12px;width:300px;transition:all .2s}.search-box:focus-within{border-color:var(--color-primary, #1B4B43);box-shadow:0 0 0 2px #1b4b431a}.search-box input{border:none;box-shadow:none;padding:10px 8px;outline:none;width:100%;font-size:.9rem}.search-icon{color:#94a3b8}.clear-search{background:none;border:none;color:#94a3b8;cursor:pointer;padding:4px;border-radius:50%;display:flex}.clear-search:hover{background:#f1f5f9;color:#64748b}.search-suggestion-banner{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af;border-radius:8px;padding:12px 16px;margin-bottom:var(--spacing-md);display:flex;justify-content:space-between;align-items:center;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.suggestion-content{display:flex;align-items:center;gap:12px;font-size:.95rem}.suggestion-action{background:#fff;border:1px solid #bfdbfe;color:#2563eb;padding:6px 12px;border-radius:6px;font-weight:500;cursor:pointer;font-size:.85rem;transition:all .2s}.suggestion-action:hover{background:#dbeafe}.patients-table-wrapper{overflow-x:auto}.patients-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.patients-table th,.patients-table td{padding:var(--spacing-sm);text-align:left;border-bottom:1px solid rgba(0,0,0,.05)}.patients-table th{background:var(--color-bg-off-white, #f8fafc);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;color:#64748b}.patients-table tr:hover{background:#f8fafc}.row-completed td{color:#94a3b8}.row-completed strong{color:#64748b;text-decoration:line-through;text-decoration-color:#0000001a}.row-completed strong{text-decoration:none}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#dcfce7;color:#166534}.status-badge.completed{background:#f1f5f9;color:#475569;border:1px solid #cbd5e1}.status-badge.on_hold{background:#fef9c3;color:#854d0e}.action-btn{background:transparent;padding:6px 12px;border-radius:6px;font-size:.85rem;color:var(--color-primary-action, #2563eb);transition:all .2s;border:none;cursor:pointer}.action-btn:hover{background:#eff6ff}.modal-content{background:#fff;border-radius:12px;max-width:800px;width:100%;max-height:90vh;overflow-y:auto;padding:2rem}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h2{margin:0;color:#1b4b43}.modal-close{background:transparent;font-size:1.5rem;padding:4px 8px;border:none;cursor:pointer;color:#64748b}.modal-close:hover{color:#000}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media(max-width:600px){.form-row{grid-template-columns:1fr}.patients-header-row{flex-direction:column;align-items:stretch}.header-actions-right{flex-direction:column}.search-box{width:100%}.tabs-container{justify-content:center}}.form-group{margin-bottom:1.25rem}.form-group label{display:block;font-size:.9rem;font-weight:500;margin-bottom:6px;color:#334155}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:6px;font-size:.95rem;font-family:inherit}.form-group textarea{resize:vertical;min-height:80px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary, #1B4B43)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1rem;border-top:1px solid #e2e8f0}.empty-state{text-align:center;padding:3rem 1rem;color:#64748b}.empty-state h3{margin-bottom:.5rem;color:#334155}.confirm-modal{max-width:400px;text-align:center;padding:2rem}.confirm-modal h2{margin-bottom:.5rem}.confirm-modal p{color:#64748b;margin-bottom:1.5rem}.delete-btn{color:#dc3545}.delete-btn:hover{background:#fef2f2}.actions-cell{white-space:nowrap}.phone-input-group{display:flex;align-items:center;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden;background:#fff}.phone-prefix{background:#f8fafc;padding:10px 12px;border-right:1px solid #e2e8f0;color:#64748b;font-weight:500;-webkit-user-select:none;user-select:none}.phone-input-group:focus-within{border-color:var(--color-primary, #1B4B43)}.inbox-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.inbox-header h2{margin:0}.inbox-count{background:var(--color-primary-action);color:#fff;padding:4px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:600}.inbox-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.inbox-item{cursor:pointer}.inbox-item.unread{border-left:4px solid var(--color-primary-action);background:#2c5f4d05}.thread-row-content{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md)}.thread-row-main{flex:1}.thread-row-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:4px}.thread-row-header h4{margin:0;font-size:var(--text-base)}.unread-badge{background:var(--color-primary-action);color:#fff;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:600;text-transform:uppercase}.thread-subject{color:var(--color-text-secondary);font-size:var(--text-sm);margin:4px 0}.inbox-meta{color:var(--color-text-secondary);font-size:var(--text-xs)}.thread-status{padding:2px 8px;border-radius:10px;font-size:var(--text-xs);text-transform:capitalize}.info-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:500;white-space:nowrap;text-decoration:none}.info-badge.treatment{background:#8b5cf61f;color:#7c3aed}.info-badge.visit{background:#3b82f61f;color:#2563eb}.info-badge.balance{background:#f59e0b1f;color:#d97706}.info-badge.phone{background:#22c55e1f;color:#16a34a;cursor:pointer;transition:var(--transition-fast)}.info-badge.phone:hover{background:#22c55e40}.thread-row-header{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.admin-thread-view{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:700px}.admin-thread-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.1);margin-bottom:var(--spacing-md)}.header-left{display:flex;align-items:flex-start;gap:var(--spacing-md)}.header-info h2{margin:0 0 4px}.header-info p{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.admin-messages-container{flex:1;overflow-y:auto;padding:var(--spacing-md);background:var(--color-bg-off-white);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-message-bubble{max-width:80%;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md)}.admin-message-bubble.patient{align-self:flex-start;background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.admin-message-bubble.admin{align-self:flex-end;background:var(--color-primary-action);color:#fff;border-bottom-right-radius:4px}.admin-message-bubble.admin .message-text,.admin-message-bubble.admin .message-time,.admin-message-bubble.admin .message-header,.admin-message-bubble.admin a{color:#fff}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;gap:var(--spacing-sm)}.message-sender{font-size:var(--text-xs);font-weight:600}.admin-message-bubble.patient .message-sender{color:var(--color-primary-action)}.admin-message-bubble.admin .message-sender{color:#fffc}.message-time{font-size:10px;opacity:.6}.message-text{margin:0;font-size:var(--text-sm);line-height:1.5}.message-file{margin-top:var(--spacing-xs)}.message-file img{max-width:250px;max-height:180px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.message-file img:hover{opacity:.9;transform:scale(1.02)}.message-file span{display:block;font-size:11px;margin-top:4px;opacity:.7}.message-file .pdf-link{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#0000000d;border-radius:var(--radius-sm);font-size:var(--text-sm);color:inherit;text-decoration:none;transition:var(--transition-fast)}.message-file .pdf-link:hover{background:#0000001a}.admin-message-bubble.admin .message-file .pdf-link{background:#fff3}.admin-message-bubble.admin .message-file .pdf-link:hover{background:#ffffff4d}.admin-reply-box{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-md);border:1px solid #e5e7eb}.attach-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-off-white);border-radius:var(--radius-sm);cursor:pointer;font-size:1.2rem;transition:var(--transition-fast);flex-shrink:0}.reply-input{flex:1;border:none;padding:var(--spacing-sm);font-size:var(--text-base);outline:none}.thread-resolved-banner{text-align:center;padding:var(--spacing-md);background:#22c55e1a;border-radius:var(--radius-md);margin-top:var(--spacing-md);color:#16a34a}.thread-resolved-banner button{background:none;border:none;color:var(--color-primary-action);text-decoration:underline;cursor:pointer;font-size:inherit}.inbox-preview{width:80px;height:80px;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0}.inbox-details{flex:1}.inbox-details h4{margin:0 0 4px}.inbox-details p{margin:0;color:var(--color-text-secondary);font-size:var(--text-sm)}.inbox-actions{display:flex;gap:var(--spacing-xs);align-items:center}.status-badge{padding:4px 12px;border-radius:20px;font-size:var(--text-xs);text-transform:capitalize}.status-badge.approved{background:#22c55e1a;color:#16a34a}.status-badge.reviewed{background:#3b82f61a;color:#3b82f6}@media(max-width:768px){.admin-thread-view{height:auto;max-height:none}.admin-thread-header{flex-direction:column;gap:var(--spacing-sm)}.header-left{flex-direction:column;width:100%}.header-actions,.header-actions .btn{width:100%}.admin-messages-container{min-height:300px}.admin-message-bubble{max-width:90%}.admin-reply-box{flex-wrap:wrap}.reply-input{order:1;width:100%;margin-bottom:var(--spacing-xs)}.attach-btn{order:0}.admin-reply-box .btn{order:2;flex:1}.thread-row-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.thread-row-action,.thread-row-action .btn{width:100%}}.receptionist-dashboard{min-height:100vh;background:var(--color-background, #f8faf9);padding-bottom:2rem}.receptionist-dashboard .container{max-width:1200px;margin:0 auto;padding:1rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-top:1rem}.header-left{text-align:left}.dashboard-header h1{font-family:Georgia,serif;color:var(--color-primary, #1B4B43);margin:0;font-size:1.75rem}.date-display{color:var(--color-text-secondary, #666);margin:.5rem 0 0;font-size:.95rem}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{display:flex;flex-direction:column;align-items:center;padding:1rem;text-align:center}.stat-icon{font-size:1.5rem;margin-bottom:.25rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-primary, #1B4B43)}.stat-label{font-size:.85rem;color:var(--color-text-secondary, #666)}.quick-actions{display:flex;gap:.75rem;margin-bottom:2rem;flex-wrap:wrap}.search-box{flex:1;min-width:200px;position:relative}.search-box input{width:100%;padding:.6rem 1rem;border:1px solid var(--color-border, #ddd);border-radius:8px;font-size:.95rem}.search-results{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--color-border, #ddd);border-radius:8px;box-shadow:0 4px 12px #0000001a;z-index:100;margin-top:4px}.search-result-item{padding:.75rem 1rem;display:flex;justify-content:space-between;cursor:pointer;border-bottom:1px solid #eee}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--color-background-alt, #f5f5f5)}.phone-input-group{display:flex;align-items:center;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);overflow:hidden;background:#fff}.phone-prefix{background:var(--bg-secondary, #f8fafc);padding:.75rem 1rem;border-right:1px solid var(--border-color, #e2e8f0);color:var(--text-secondary, #64748b);font-weight:500;-webkit-user-select:none;user-select:none}.phone-input-group input{border:none!important;border-radius:0!important;padding-left:1rem!important;outline:none!important;box-shadow:none!important}.phone-input-group:focus-within{border-color:var(--color-primary, #1B4B43);box-shadow:0 0 0 2px #1b4b431a}.appointments-section{margin-bottom:2rem}.appointments-section h2{font-size:1.1rem;color:var(--color-primary, #1B4B43);margin-bottom:1rem;font-family:Georgia,serif}.empty-card{padding:1.5rem;text-align:center;color:var(--color-text-secondary, #666)}.appointments-table,.today-table{display:flex;flex-direction:column;gap:.5rem}.table-header{display:grid;padding:.5rem 1rem;font-weight:600;color:var(--color-text-secondary, #666);font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.appointments-table .table-header{grid-template-columns:100px 1fr 140px 150px}.today-table .table-header{grid-template-columns:100px 1fr 80px 80px 80px 140px}.appointment-row{display:grid;align-items:center;padding:.75rem 1rem;gap:.5rem;transition:all .2s}.appointments-table .appointment-row{grid-template-columns:100px 1fr 140px 150px}.today-table .appointment-row{grid-template-columns:100px 1fr 80px 80px 80px 140px}.appointment-row.completed{background:var(--color-success-bg, #d4edda);border-color:var(--color-success, #28a745)}.appointment-row .time{font-weight:600;color:var(--color-primary, #1B4B43);display:flex;flex-direction:column;gap:.25rem}.walk-in-badge{font-size:.7rem;background:var(--color-accent, #F5E6D3);color:var(--color-primary, #1B4B43);padding:.1rem .4rem;border-radius:4px;width:fit-content}.appointment-row .patient-name{font-weight:500;display:flex;flex-direction:column;gap:.25rem}.phone-link{color:var(--color-primary-action, #2563eb);text-decoration:none;font-size:.9rem}.phone-link:hover{text-decoration:underline}.phone-small{font-size:.8rem;color:var(--color-text-secondary, #666);text-decoration:none}.checkbox-cell{text-align:center}.status-checkbox{background:none;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;transition:transform .2s}.status-checkbox:hover:not(:disabled){transform:scale(1.2)}.status-checkbox:disabled{cursor:not-allowed;opacity:.7}.auto-check{color:var(--color-text-secondary, #666)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500}.status-badge.confirmed{background:#d4edda;color:#155724}.actions{display:flex;gap:.5rem;justify-content:flex-end}.actions button{padding:.35rem .75rem;font-size:.85rem}.today-section h2{color:var(--color-primary, #1B4B43)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto}.modal-content.modal-small{max-width:400px}.modal-content.modal-large{max-width:800px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border, #ddd)}.modal-header h2{margin:0;font-size:1.25rem;color:var(--color-primary, #1B4B43)}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary, #666);line-height:1}.modal-close:hover{color:var(--color-text, #333)}.modal-content form,.modal-content>div:not(.modal-header){padding:1.25rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.4rem;font-weight:500;color:var(--color-text, #333);font-size:.9rem}.form-group input,.form-group select,.form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border, #ddd);border-radius:6px;font-size:.95rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary, #1B4B43)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}@media(max-width:600px){.modal-content{margin:.5rem}.modal-content form,.modal-content>div:not(.modal-header){padding:1.25rem}.form-row{grid-template-columns:1fr}}.form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--color-border, #ddd)}.patient-info{margin:0 0 1rem;padding:.75rem;background:var(--color-background-alt, #f5f5f5);border-radius:6px}.walk-in-search .search-results-list{border:1px solid var(--color-border, #ddd);border-radius:8px;margin-top:.5rem}.selected-patient{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--color-success-bg, #d4edda);border-radius:6px}.invoices-list{display:flex;flex-direction:column;gap:1rem}.invoice-item{padding:1rem;border:1px solid var(--color-border, #ddd);border-radius:8px}.invoice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.invoice-number{font-weight:600;color:var(--color-primary, #1B4B43)}.invoice-status{padding:.2rem .6rem;border-radius:12px;font-size:.8rem;text-transform:capitalize}.invoice-status.paid{background:#d4edda;color:#155724}.invoice-status.partial{background:#fff3cd;color:#856404}.invoice-status.sent,.invoice-status.draft{background:#cfe2ff;color:#084298}.invoice-details{display:flex;gap:1rem;margin-bottom:.75rem;font-size:.9rem}.invoice-details .balance{font-weight:600;color:var(--color-warning, #dc3545)}.empty-message{text-align:center;color:var(--color-text-secondary, #666);padding:2rem}.sub-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1100}.sub-modal-content{background:#fff;border-radius:12px;padding:1.5rem;max-width:350px;width:90%;box-shadow:0 8px 32px #0003}.sub-modal-content h3{margin:0 0 .5rem;color:var(--color-primary, #1B4B43)}.sub-modal-content p{margin:0 0 1rem;color:var(--color-text-secondary, #666);font-size:.9rem}@media(max-width:768px){.stats-row{grid-template-columns:repeat(2,1fr)}.quick-actions{flex-direction:column}.search-box{min-width:100%}.appointments-table .table-header,.today-table .table-header{display:none}.appointments-table .appointment-row{grid-template-columns:1fr;gap:.5rem}.today-table .appointment-row{grid-template-columns:1fr;gap:.75rem}.appointment-row .time{flex-direction:row;align-items:center;gap:.5rem}.checkbox-cell{display:inline-flex;align-items:center;gap:.5rem}.checkbox-cell:before{font-size:.75rem;color:var(--color-text-secondary, #666)}.today-table .appointment-row .checkbox-cell:nth-child(3):before{content:"Confirm: "}.today-table .appointment-row .checkbox-cell:nth-child(4):before{content:"Check-In: "}.today-table .appointment-row .checkbox-cell:nth-child(5):before{content:"Done: "}.actions{justify-content:flex-start;padding-top:.5rem;border-top:1px solid #eee}.form-row{grid-template-columns:1fr}}.admin-dashboard-compact{padding-top:var(--spacing-sm)!important}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-sm)}.dashboard-header.compact{margin-bottom:var(--spacing-sm)}.dashboard-header.compact h1{font-size:var(--text-2xl);margin-bottom:0}.dashboard-header h1{font-size:var(--text-3xl)}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stat-card{text-align:center;padding:var(--spacing-md)}.stat-card h3{font-size:var(--text-4xl);color:var(--color-primary-action);margin-bottom:var(--spacing-xs)}.stat-card p{font-size:var(--text-sm);text-transform:uppercase;letter-spacing:1px}.dashboard-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.1);padding-bottom:var(--spacing-xs)}.tab-btn{background:transparent;padding:12px 20px;font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:var(--transition-fast);position:relative}.tab-btn:hover{background:var(--color-accent-mint);color:var(--color-text-primary)}.tab-btn.active{color:var(--color-primary-action);background:#2c5f4d0d}.tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:3px;background:var(--color-primary-action);border-radius:3px 3px 0 0}.tab-content{min-height:300px}.invoices-tab .invoices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.invoices-tab .invoices-header h3{margin:0;font-size:var(--text-xl)}.invoice-card{padding:0;overflow:hidden}.invoice-row{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);cursor:pointer;transition:var(--transition-fast)}.invoice-row:hover{background:var(--color-bg-off-white)}.invoice-main{display:flex;align-items:center;gap:var(--spacing-sm)}.invoice-number{font-weight:600;font-size:var(--text-base)}.invoice-date{color:var(--color-text-secondary);font-size:var(--text-sm)}.invoice-status-badge{padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600}.invoice-amounts{text-align:right}.invoice-total{font-weight:600;font-size:var(--text-lg)}.invoice-balance{display:block;font-size:var(--text-xs);color:#f59e0b}.expand-icon{font-size:10px;color:var(--color-text-muted);margin-left:var(--spacing-sm)}.invoice-details{padding:var(--spacing-md);background:var(--color-bg-off-white);border-top:1px solid rgba(0,0,0,.08)}.invoice-items-table{width:100%;border-collapse:collapse;margin-bottom:var(--spacing-md);font-size:var(--text-sm)}.invoice-items-table th{text-align:left;padding:8px;background:#2c5f4d0d;font-weight:600;font-size:var(--text-xs);text-transform:uppercase;color:var(--color-text-secondary)}.invoice-items-table td{padding:8px;border-bottom:1px solid rgba(0,0,0,.05)}.invoice-summary{max-width:250px;margin-left:auto;margin-bottom:var(--spacing-md)}.summary-row{display:flex;justify-content:space-between;padding:4px 0;font-size:var(--text-sm)}.summary-row.total{font-weight:600;font-size:var(--text-base);border-top:1px solid rgba(0,0,0,.1);padding-top:8px;margin-top:4px}.summary-row.paid{color:#16a34a}.summary-row.balance{color:#f59e0b}.payment-history{margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-sm)}.payment-history h4{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.payment-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:var(--text-sm);border-bottom:1px solid rgba(0,0,0,.05)}.payment-row:last-child{border-bottom:none}.payment-method{background:var(--color-accent-mint);color:var(--color-primary-action);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:capitalize}.payment-amount{font-weight:600;color:#16a34a}.receipt-btn{background:none;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:var(--radius-sm);transition:var(--transition-fast)}.receipt-btn:hover{background:var(--color-bg-off-white)}.invoice-actions{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.line-items{display:flex;flex-direction:column;gap:var(--spacing-sm)}.line-item-row{display:flex;gap:var(--spacing-xs);align-items:center}.line-item-row .item-desc{flex:3}.line-item-row .item-qty{width:70px}.line-item-row .item-rate{width:100px}.line-item-row .item-amount{width:100px;text-align:right;font-weight:500}.line-item-row .remove-item{width:30px;height:30px;border-radius:50%;background:#ef44441a;color:#ef4444;border:none;cursor:pointer;font-size:18px}.invoice-totals{margin:var(--spacing-md) 0;padding:var(--spacing-md);background:var(--color-bg-off-white);border-radius:var(--radius-sm)}.invoice-totals .totals-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.invoice-totals .discount-input,.invoice-totals .tax-input{display:flex;align-items:center;gap:var(--spacing-sm)}.invoice-totals .discount-input input,.invoice-totals .tax-input input{width:80px}.invoice-totals .total-final{font-size:var(--text-xl);font-weight:600;color:var(--color-primary-action);border-top:2px solid var(--color-primary-action);padding-top:var(--spacing-sm);margin-top:var(--spacing-sm)}.payment-info{background:var(--color-bg-off-white);padding:var(--spacing-md);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md)}@media(max-width:768px){.invoice-row{flex-wrap:wrap;gap:var(--spacing-sm)}.invoice-main{flex-wrap:wrap}.invoice-amounts{text-align:left;width:100%}.line-item-row{flex-wrap:wrap}.line-item-row .item-desc{width:100%;flex:none}.invoice-actions{flex-direction:column}.invoice-actions .btn{width:100%}}.patient-detail{max-width:1000px;margin:0 auto}.patient-detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.patient-detail-header h1{font-size:var(--text-3xl);margin-bottom:4px}.patient-meta{display:flex;gap:var(--spacing-md);flex-wrap:wrap;color:var(--color-text-secondary);font-size:var(--text-sm)}.patient-meta span{display:flex;align-items:center;gap:4px}.header-actions{display:flex;gap:var(--spacing-xs)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.info-card{padding:var(--spacing-md)}.info-card h4{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);margin-bottom:4px}.info-card p{font-size:var(--text-lg);color:var(--color-text-primary);font-weight:500}.detail-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.1);padding-bottom:var(--spacing-xs);overflow-x:auto}.detail-tabs .tab-btn{background:transparent;padding:12px 20px;font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:var(--transition-fast);position:relative;white-space:nowrap;border:none;cursor:pointer}.detail-tabs .tab-btn:hover{background:var(--color-accent-mint)}.detail-tabs .tab-btn.active{color:var(--color-primary-action);background:#2c5f4d0d}.detail-tabs .tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:3px;background:var(--color-primary-action)}.timeline{position:relative;padding-left:var(--spacing-lg)}.timeline:before{content:"";position:absolute;left:8px;top:0;bottom:0;width:2px;background:var(--color-accent-teal)}.timeline-item{position:relative;margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.timeline-item:before{content:"";position:absolute;left:calc(-1 * var(--spacing-lg) + 4px);top:var(--spacing-md);width:12px;height:12px;background:var(--color-primary-action);border-radius:50%;border:2px solid white}.timeline-date{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.timeline-item h4{font-size:var(--text-base);margin-bottom:var(--spacing-xs);text-transform:capitalize}.timeline-item p{font-size:var(--text-sm)}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-md)}.file-card{background:#fff;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:var(--transition-fast)}.file-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.file-preview{position:relative;aspect-ratio:4/3;background:var(--color-bg-off-white)}.file-preview img{width:100%;height:100%;object-fit:cover}.file-type-badge{position:absolute;top:8px;left:8px;padding:4px 10px;background:var(--color-primary-action);color:#fff;font-size:var(--text-xs);text-transform:uppercase;font-weight:600;border-radius:var(--radius-sm)}.file-info{padding:var(--spacing-sm)}.file-info .file-name{font-weight:500;font-size:var(--text-sm);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-info .file-desc{color:var(--color-text-secondary);font-size:var(--text-xs);margin-bottom:4px}.file-info .file-date{color:var(--color-text-secondary);font-size:var(--text-xs)}.lightbox{display:flex;align-items:center;justify-content:center}.lightbox-content{background:#fff;border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;overflow:hidden;position:relative}.lightbox-content>img{max-width:100%;max-height:70vh;display:block}.lightbox-content .modal-close{position:absolute;top:12px;right:12px;background:#00000080;color:#fff;z-index:10}.lightbox-info{padding:var(--spacing-md);background:#fff}.lightbox-info h3{font-size:var(--text-base);margin-bottom:4px}.lightbox-info p{color:var(--color-text-secondary);font-size:var(--text-sm)}.lightbox-info .file-meta{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.5px;margin-top:8px}.notes-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.notes-header h3{margin:0}.notes-editor textarea{width:100%;min-height:200px;padding:var(--spacing-md);border:1px solid #ddd;border-radius:var(--radius-sm);font-family:inherit;font-size:var(--text-base);resize:vertical;margin-bottom:var(--spacing-md)}.notes-editor textarea:focus{outline:none;border-color:var(--color-primary-action)}.portal-badge{background:linear-gradient(135deg,var(--color-primary-action),var(--color-accent-teal));color:#fff;padding:4px 10px;border-radius:20px;font-size:var(--text-xs);font-weight:600}.portal-status{padding:var(--spacing-md) 0}.portal-active,.portal-inactive{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.portal-active{background:#22c55e1a;border:1px solid rgba(34,197,94,.3)}.portal-inactive{background:#00000005;border:1px solid rgba(0,0,0,.1)}.portal-icon{font-size:2rem}.portal-active h4,.portal-inactive h4{margin-bottom:4px}.portal-active p,.portal-inactive p{color:var(--color-text-secondary);font-size:var(--text-sm)}.portal-url code{background:#0000000d;padding:2px 6px;border-radius:4px;font-size:var(--text-xs)}.portal-note{color:var(--color-text-secondary);font-size:var(--text-sm);font-style:italic}.modal-subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.password-field{display:flex;align-items:center}.password-field input{flex:1}.login-created{text-align:center;padding:var(--spacing-lg)}.success-icon{font-size:3rem;margin-bottom:var(--spacing-sm)}.login-created h3{color:#22c55e;margin-bottom:var(--spacing-md)}.credentials-box{background:var(--color-bg-off-white);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:left;margin:var(--spacing-md) 0}.credentials-box p{margin:8px 0;font-size:var(--text-sm)}.error-message{background:#ef44441a;color:#dc2626;padding:var(--spacing-sm);border-radius:var(--radius-sm);margin-bottom:var(--spacing-md);font-size:var(--text-sm)}.treatment-plans-section{max-width:100%}.plans-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.plans-header h3{margin:0}.plans-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.plan-card{padding:var(--spacing-md)}.plan-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md)}.plan-header h4{margin:0 0 4px}.plan-description{color:var(--color-text-secondary);font-size:var(--text-sm);margin:0}.plan-status{padding:4px 10px;border-radius:12px;font-size:var(--text-xs);text-transform:capitalize}.plan-status.planned{background:#64748b1a;color:#64748b}.plan-status.in_progress{background:#3b82f61a;color:#3b82f6}.plan-status.completed{background:#22c55e1a;color:#16a34a}.plan-progress{margin-bottom:var(--spacing-md)}.progress-bar{height:8px;background:var(--color-bg-off-white);border-radius:4px;overflow:hidden;margin-bottom:6px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-action),var(--color-accent-teal));border-radius:4px;transition:width .3s ease}.plan-progress span{font-size:var(--text-xs);color:var(--color-text-secondary)}.phases-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.phase-item{display:flex;flex-direction:column;padding:var(--spacing-sm);background:var(--color-bg-off-white);border-radius:var(--radius-sm);cursor:pointer;border-left:3px solid #ddd;transition:var(--transition-fast)}.phase-item:hover{background:#00000008}.phase-item.pending{border-left-color:#94a3b8}.phase-item.in_progress{border-left-color:#3b82f6;background:#3b82f60d}.phase-item.completed{border-left-color:#16a34a;background:#22c55e0d}.phase-header{display:flex;align-items:center;gap:var(--spacing-sm)}.phase-number{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:50%;font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.phase-item.completed .phase-number{background:#16a34a;color:#fff}.phase-title{flex:1;font-size:var(--text-sm)}.phase-status-select{padding:4px 8px;border-radius:4px;border:1px solid #ddd;font-size:11px;cursor:pointer}.phase-description{margin:8px 0 0 32px;color:var(--color-text-secondary);font-size:var(--text-xs)}.phases-editor{display:flex;flex-direction:column;gap:var(--spacing-xs)}.phase-edit-row{display:flex;align-items:center;gap:var(--spacing-xs)}.phase-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-off-white);border-radius:50%;font-size:var(--text-xs);font-weight:600;flex-shrink:0}.phase-edit-row input{flex:1;min-width:0}.remove-phase{width:28px;height:28px;border:none;background:#ef44441a;color:#dc2626;border-radius:4px;cursor:pointer;font-size:16px}.remove-phase:hover{background:#ef444433}.modal-large{max-width:650px}@media(max-width:768px){.patient-detail-header{flex-direction:column;align-items:flex-start}.patient-detail-header h1{font-size:var(--text-2xl)}.header-actions{width:100%;flex-wrap:wrap}.header-actions .btn{flex:1;min-width:120px}.info-grid{grid-template-columns:repeat(2,1fr)}.detail-tabs{gap:4px}.detail-tabs .tab-btn{padding:10px 12px;font-size:var(--text-sm)}.timeline{padding-left:var(--spacing-md)}.timeline-item:before{left:calc(-1 * var(--spacing-md) + 3px);width:10px;height:10px}.files-grid{grid-template-columns:repeat(2,1fr)}.modal-content,.modal-large{max-width:100%;margin:0 var(--spacing-sm);padding:var(--spacing-md)}.plans-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.phase-edit-row{flex-wrap:wrap}.phase-edit-row input{min-width:100%}}@media(max-width:480px){.info-grid,.files-grid{grid-template-columns:1fr}.header-actions .btn{width:100%}}.messages-section{max-width:800px}.messages-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.messages-header h2{margin-bottom:4px}.messages-header p{color:var(--color-text-secondary);font-size:var(--text-sm)}.thread-card{cursor:pointer;position:relative}.thread-card.unread{border-left:4px solid var(--color-primary-action)}.thread-content{display:flex;justify-content:space-between;align-items:center}.thread-info{display:flex;align-items:center;gap:var(--spacing-sm)}.thread-info h4{margin:0;font-size:var(--text-base)}.thread-status{padding:2px 8px;border-radius:12px;font-size:var(--text-xs);text-transform:capitalize}.thread-status.open{background:#22c55e1a;color:#16a34a}.thread-status.resolved{background:#64748b1a;color:#64748b}.thread-date{color:var(--color-text-secondary);font-size:var(--text-xs)}.unread-dot{width:10px;height:10px;background:var(--color-primary-action);border-radius:50%;position:absolute;top:50%;right:var(--spacing-md);transform:translateY(-50%)}.thread-view{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:700px}.thread-view-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.1)}.thread-view-header h2{flex:1;margin:0;font-size:var(--text-xl)}.messages-container{flex:1;overflow-y:auto;padding:var(--spacing-md);background:var(--color-bg-off-white);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-md)}.message-bubble{max-width:80%;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);position:relative}.message-bubble.patient{align-self:flex-end;background:var(--color-primary-action);color:#fff;border-bottom-right-radius:4px}.message-bubble.admin{align-self:flex-start;background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px}.message-sender{font-size:var(--text-xs);font-weight:600;margin-bottom:4px;opacity:.8}.message-bubble.patient .message-sender{color:#fffc}.message-bubble.admin .message-sender{color:var(--color-primary-action)}.message-bubble p{margin:0;font-size:var(--text-sm);line-height:1.5}.message-bubble.patient p{color:#fff}.message-time{font-size:10px;opacity:.6;margin-top:4px;display:block;text-align:right}.message-bubble.patient .message-time{color:#fffc}.message-attachment{margin-top:var(--spacing-xs)}.message-attachment img{max-width:200px;max-height:150px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition-fast)}.message-attachment img:hover{opacity:.9}.message-attachment span{display:block;font-size:11px;margin-top:4px;opacity:.7}.message-composer{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-md);border:1px solid #e5e7eb}.message-composer input[type=text]{flex:1;border:none;padding:var(--spacing-sm);font-size:var(--text-base);outline:none}.attach-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-off-white);border-radius:var(--radius-sm);cursor:pointer;font-size:1.2rem;transition:var(--transition-fast)}.attach-btn:hover{background:var(--color-accent-mint)}.attached-file{font-size:var(--text-xs);color:var(--color-primary-action);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-resolved{text-align:center;padding:var(--spacing-md);background:#22c55e1a;border-radius:var(--radius-md);margin-top:var(--spacing-md);color:#16a34a}.empty-state{text-align:center;padding:var(--spacing-xl)}.empty-state h3{margin-bottom:var(--spacing-xs)}.empty-state p{color:var(--color-text-secondary)}.my-uploads-section{max-width:600px}.upload-zone{padding:var(--spacing-xl);text-align:center;cursor:pointer;border:2px dashed #ddd;border-radius:var(--radius-md);transition:var(--transition-fast)}.upload-zone:hover,.upload-zone.dragging{border-color:var(--color-primary-action);background:#2c5f4d05}.upload-zone input{display:none}.upload-icon{font-size:2.5rem;margin-bottom:var(--spacing-sm)}.upload-form{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid #eee}.my-uploads-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:var(--spacing-sm)}.upload-thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;position:relative;background:var(--color-bg-off-white)}.upload-thumb img{width:100%;height:100%;object-fit:cover}.upload-status{position:absolute;bottom:4px;right:4px;padding:2px 6px;border-radius:4px;font-size:10px;text-transform:capitalize;background:#000000b3;color:#fff}.upload-status.approved{background:#16a34a}.upload-status.pending{background:#f59e0b}.upload-status.reviewed{background:#3b82f6}@media(max-width:768px){.messages-section{max-width:100%}.thread-view{height:auto;max-height:none}.thread-view-header{flex-direction:column;gap:var(--spacing-sm)}.thread-view-header h2{font-size:var(--text-lg)}.messages-container{min-height:250px;max-height:400px}.message-bubble{max-width:90%}.message-composer{flex-wrap:wrap}.message-composer input[type=text]{order:1;width:100%;margin-bottom:var(--spacing-xs)}.attach-btn{order:0}.message-composer .btn{order:2;flex:1}.message-attachment img{max-width:150px;max-height:120px}.new-message-section{padding:var(--spacing-sm)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:var(--spacing-md)}.modal-content{background:#fff;border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;overflow-y:auto;padding:var(--spacing-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.modal-header h2{margin:0;font-size:var(--text-xl)}.modal-close{background:transparent;font-size:var(--text-xl);padding:4px 8px;border:none;cursor:pointer}.modal-content .form-group{margin-bottom:var(--spacing-md)}.modal-content .form-group label{display:block;margin-bottom:6px;font-weight:600;font-size:var(--text-sm)}.modal-content .form-group input,.modal-content .form-group textarea{width:100%;padding:10px 12px;border:1px solid rgba(0,0,0,.15);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit}.modal-content .form-group textarea{resize:vertical}.modal-content .form-actions{display:flex;justify-content:flex-end;gap:var(--spacing-sm);margin-top:var(--spacing-md)}@media(max-width:600px){.modal-content{margin:.5rem}}.patient-messages{padding:0}.messages-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.messages-toolbar h3{margin:0;font-size:var(--text-xl)}.new-thread-form{margin-bottom:var(--spacing-md);padding:var(--spacing-md)}.new-thread-form h4{margin:0 0 var(--spacing-sm) 0}.new-thread-form input{width:100%;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm);font-size:var(--text-base)}.new-thread-form .form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.threads-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.thread-item{cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.thread-item:hover{transform:translate(4px);border-left:3px solid var(--color-primary-action)}.thread-item.unread{background:#2c5f4d0d;border-left:3px solid var(--color-primary-action)}.thread-info h4{margin:0 0 4px;font-size:var(--text-base)}.thread-meta{display:flex;gap:var(--spacing-sm);font-size:var(--text-sm);color:var(--color-text-muted)}.thread-meta .status{text-transform:capitalize;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs)}.thread-meta .status.open{background:#2c5f4d1a;color:var(--color-primary-action)}.thread-meta .status.resolved{background:#0000000d;color:var(--color-text-muted)}.unread-dot{width:10px;height:10px;background:var(--color-primary-action);border-radius:50%;flex-shrink:0}.thread-view .thread-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.thread-header .back-btn{background:none;border:1px solid var(--color-border);padding:8px 16px;border-radius:var(--radius-md);cursor:pointer;font-size:var(--text-sm)}.thread-header .back-btn:hover{background:var(--color-bg-secondary)}.thread-header h3{margin:0;flex:1}.messages-container{max-height:400px;overflow-y:auto;padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.message{margin-bottom:var(--spacing-md)}.message.patient{text-align:right}.message.admin{text-align:left}.message-bubble{display:inline-block;padding:12px 16px;border-radius:var(--radius-lg);max-width:70%;text-align:left}.message.patient .message-bubble{background:var(--color-primary-action);color:#fff}.message.admin .message-bubble{background:#fff;border:1px solid var(--color-border)}.message-time{display:block;font-size:var(--text-xs);color:var(--color-text-muted);margin-top:4px}.message .attachment{display:block;margin-top:8px;font-size:var(--text-sm);color:inherit;opacity:.9}.message.patient .attachment{color:#fff}.message-input{display:flex;gap:var(--spacing-sm)}.message-input input{flex:1;padding:12px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-base)}.message-input input:focus{outline:none;border-color:var(--color-primary-action)}.resolved-notice{text-align:center;color:var(--color-text-muted);font-style:italic;padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.patient-messages .empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.message-input-container{display:flex;flex-direction:column;gap:var(--spacing-xs)}.file-error{background:#ef44441a;color:#dc2626;padding:10px 14px;border-radius:var(--radius-md);font-size:var(--text-sm);border-left:3px solid #dc2626}.file-preview-bar{display:flex;align-items:center;gap:var(--spacing-sm);padding:8px 12px;background:var(--color-accent-mint);border-radius:var(--radius-md);font-size:var(--text-sm)}.file-preview-bar .file-name{flex:1;font-weight:500;color:var(--color-primary-action);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-preview-bar .file-size{color:var(--color-text-muted);font-size:var(--text-xs)}.file-preview-bar .remove-file{width:24px;height:24px;border-radius:50%;background:#0000001a;border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.file-preview-bar .remove-file:hover{background:#ef444433;color:#dc2626}.message-input .attach-btn{width:44px;height:44px;border-radius:var(--radius-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast);flex-shrink:0}.message-input .attach-btn:hover{background:var(--color-accent-mint);border-color:var(--color-primary-action)}.message-attachment{margin-top:8px}.message-attachment .image-attachment{max-width:200px;max-height:200px;border-radius:var(--radius-sm);cursor:pointer;transition:transform .2s ease}.message-attachment .image-attachment:hover{transform:scale(1.02)}.message-attachment .pdf-attachment{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;background:#fff3;border-radius:var(--radius-sm);font-size:var(--text-sm);color:inherit;text-decoration:none;transition:var(--transition-fast)}.message.patient .pdf-attachment{background:#fff3;color:#fff}.message.admin .pdf-attachment{background:var(--color-bg-secondary);color:var(--color-text-primary)}.message-attachment .pdf-attachment:hover{background:#ffffff4d}.message.admin .message-attachment .pdf-attachment:hover{background:var(--color-accent-mint)}.message-bubble p{margin:0}.message-sender-name{font-size:var(--text-xs);font-weight:600;margin-bottom:4px;opacity:.8}.message.patient .message-sender-name{text-align:right;color:var(--color-primary-action)}.message.admin .message-sender-name{text-align:left;color:var(--color-text-secondary)}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;cursor:zoom-out}.lightbox-image{max-width:90%;max-height:90vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 20px 60px #00000080}.lightbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;background:#fff;border:none;border-radius:50%;font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition-fast)}.lightbox-close:hover{background:#f0f0f0;transform:scale(1.1)}.patient-portal{max-width:900px}.portal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-sm)}.portal-header h1{font-size:var(--text-3xl);margin-bottom:4px}.treatment-badge{display:inline-block;background:var(--color-accent-mint);color:var(--color-primary-action);padding:4px 12px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600}.status-card{display:flex;justify-content:space-around;padding:var(--spacing-md);margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.status-item{text-align:center}.status-label{display:block;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary);margin-bottom:4px}.status-value{font-size:var(--text-xl);font-weight:600;color:var(--color-text-primary)}.status-value.active{color:#28a745}.status-value.completed{color:var(--color-primary-action)}.appointment-banner{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#2c5f4d0d,#3b82f60d)}.appointment-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-accent-mint);font-size:1.5rem}.appointment-info{display:flex;flex-direction:column}.appointment-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.appointment-date{font-size:var(--text-lg);font-weight:600;color:var(--color-text-primary)}.appointment-treatment{font-size:var(--text-sm);color:var(--color-text-secondary)}.portal-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.1);padding-bottom:var(--spacing-xs);overflow-x:auto}.portal-tabs .tab-btn{background:transparent;padding:12px 20px;font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:var(--transition-fast);position:relative;white-space:nowrap}.portal-tabs .tab-btn:hover{background:var(--color-accent-mint);color:var(--color-text-primary)}.portal-tabs .tab-btn.active{color:var(--color-primary-action);background:#2c5f4d0d}.portal-tabs .tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:3px;background:var(--color-primary-action);border-radius:3px 3px 0 0}.tab-badge{background:var(--color-primary-action);color:#fff;padding:2px 7px;border-radius:10px;font-size:11px;font-weight:600;margin-left:6px}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-bg-off-white);border-top:4px solid var(--color-primary-action);border-radius:50%;margin:0 auto var(--spacing-sm);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.overview-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.treatment-plan-card{padding:var(--spacing-md)}.plan-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.plan-card-header h3{margin:0;font-size:var(--text-xl)}.plan-status-badge{padding:4px 12px;border-radius:20px;font-size:var(--text-xs);font-weight:600;text-transform:capitalize}.plan-status-badge.planned{background:#64748b1a;color:#64748b}.plan-status-badge.in_progress{background:#3b82f61a;color:#3b82f6}.plan-status-badge.completed{background:#22c55e1a;color:#16a34a}.plan-description{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);font-size:var(--text-sm)}.treatment-progress{margin-bottom:var(--spacing-md)}.progress-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:var(--text-xs);color:var(--color-text-secondary)}.progress-track{height:10px;background:var(--color-bg-off-white);border-radius:5px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-action),var(--color-accent-teal));border-radius:5px;transition:width .4s ease}.phases-timeline{border-top:1px solid rgba(0,0,0,.08);padding-top:var(--spacing-md)}.phases-timeline h4{margin-bottom:var(--spacing-sm);font-size:var(--text-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.phase-row{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-sm);margin-bottom:var(--spacing-xs);position:relative}.phase-row:before{content:"";position:absolute;left:15px;top:100%;width:2px;height:8px;background:#e5e7eb}.phase-row:last-child:before{display:none}.phase-row.completed{background:#22c55e0d}.phase-row.completed:before{background:#16a34a}.phase-row.in_progress{background:#3b82f60d}.phase-indicator{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:var(--text-xs);font-weight:600;flex-shrink:0;background:#e5e7eb;color:#64748b}.phase-row.completed .phase-indicator{background:#16a34a;color:#fff}.phase-row.in_progress .phase-indicator{background:#3b82f6;color:#fff}.phase-info{flex:1;display:flex;flex-direction:column}.phase-name{font-weight:500;font-size:var(--text-sm)}.phase-desc{font-size:var(--text-xs);color:var(--color-text-secondary)}.phase-status{padding:2px 8px;border-radius:10px;font-size:10px;text-transform:capitalize}.phase-status.pending{background:#64748b1a;color:#64748b}.phase-status.in_progress{background:#3b82f61a;color:#3b82f6}.phase-status.completed{background:#22c55e1a;color:#16a34a}.visits-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.visits-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.visit-card{padding:var(--spacing-md)}.visit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.visit-date{font-weight:600;font-size:var(--text-lg);color:var(--color-text-primary)}.visit-type{padding:4px 10px;background:var(--color-accent-mint);color:var(--color-primary-action);font-size:var(--text-xs);font-weight:600;border-radius:var(--radius-full);text-transform:capitalize}.visit-treatment,.visit-notes,.visit-next{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.visit-treatment strong,.visit-notes strong,.visit-next strong{color:var(--color-text-primary)}.visit-amount{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid rgba(0,0,0,.05);font-size:var(--text-lg);font-weight:600;color:var(--color-primary-action)}.payment-badge{font-size:var(--text-xs);padding:2px 8px;border-radius:var(--radius-full);text-transform:capitalize;font-weight:500}.payment-badge.paid{background:#22c55e1a;color:#16a34a}.payment-badge.pending{background:#f59e0b1a;color:#f59e0b}.payment-badge.partial{background:#3b82f61a;color:#3b82f6}.files-section{display:flex;flex-direction:column}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.file-card{padding:var(--spacing-sm);display:flex;flex-direction:column;cursor:pointer}.file-preview{aspect-ratio:4/3;background:var(--color-bg-off-white);border-radius:var(--radius-sm);overflow:hidden;margin-bottom:var(--spacing-sm);display:flex;align-items:center;justify-content:center}.file-preview img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.file-card:hover .file-preview img{transform:scale(1.05)}.file-icon{font-size:3rem}.file-info h4{font-size:var(--text-sm);margin-bottom:4px;word-break:break-word}.file-type-badge{display:inline-block;background:var(--color-accent-mint);color:var(--color-primary-action);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.file-description{font-size:var(--text-xs);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.file-date{font-size:var(--text-xs);color:var(--color-text-muted)}.profile-section{max-width:600px}.profile-card{padding:var(--spacing-lg)}.profile-card h3{margin-bottom:var(--spacing-md);font-size:var(--text-xl);color:var(--color-text-primary)}.profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md)}.profile-field{display:flex;flex-direction:column;gap:4px}.profile-field.full-width{grid-column:span 2}.profile-field label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.profile-field span{font-size:var(--text-base);color:var(--color-text-primary)}.profile-note{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid rgba(0,0,0,.08);font-size:var(--text-sm);color:var(--color-text-muted)}.lightbox-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.lightbox-content{background:var(--color-bg-white);border-radius:var(--radius-lg);max-width:90%;max-height:90%;display:flex;flex-direction:column;overflow:hidden;position:relative}.lightbox-close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);width:36px;height:36px;border-radius:50%;background:#00000080;color:#fff;font-size:1.5rem;display:flex;align-items:center;justify-content:center;z-index:10;transition:var(--transition-fast)}.lightbox-close:hover{background:#000c}.lightbox-header{padding:var(--spacing-md);border-bottom:1px solid rgba(0,0,0,.08)}.lightbox-type{display:inline-block;background:var(--color-accent-mint);color:var(--color-primary-action);padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);text-transform:uppercase;margin-bottom:var(--spacing-xs)}.lightbox-header h3{margin:0 0 4px;font-size:var(--text-lg)}.lightbox-header p{margin:0;font-size:var(--text-sm);color:var(--color-text-secondary)}.lightbox-body{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.lightbox-body img{max-width:100%;max-height:70vh;object-fit:contain}.lightbox-body iframe{width:100%;height:70vh;border:none}.lightbox-footer{padding:var(--spacing-md);border-top:1px solid rgba(0,0,0,.08);text-align:center}.download-btn{display:inline-block;padding:10px 24px;background:var(--color-primary-action);color:#fff;border-radius:var(--radius-sm);font-weight:500;transition:var(--transition-fast)}.download-btn:hover{background:var(--color-primary-action-hover)}.empty-state{text-align:center;padding:var(--spacing-xl) var(--spacing-md);color:var(--color-text-secondary)}.empty-state h3{margin-bottom:var(--spacing-xs);color:var(--color-text-primary)}.invoices-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.invoices-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.invoice-card-patient{padding:0;overflow:hidden}.invoice-header-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);cursor:pointer;transition:var(--transition-fast)}.invoice-header-row:hover{background:var(--color-bg-off-white)}.invoice-main-info{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.invoice-num{font-weight:600}.invoice-date-text{color:var(--color-text-secondary);font-size:var(--text-sm)}.status-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:capitalize}.status-badge.paid{background:#22c55e1a;color:#16a34a}.status-badge.sent{background:#3b82f61a;color:#3b82f6}.status-badge.partial{background:#f59e0b1a;color:#f59e0b}.status-badge.overdue{background:#ef44441a;color:#ef4444}.invoice-amount-info{text-align:right}.total-amount{font-size:var(--text-lg);font-weight:600}.balance-text{display:block;font-size:var(--text-xs);color:#f59e0b}.invoice-expanded{padding:var(--spacing-md);background:var(--color-bg-off-white);border-top:1px solid rgba(0,0,0,.08)}.items-table{width:100%;border-collapse:collapse;margin-bottom:var(--spacing-md);font-size:var(--text-sm)}.items-table th{text-align:left;padding:8px;background:#2c5f4d0d;font-weight:600;font-size:var(--text-xs)}.items-table td{padding:8px;border-bottom:1px solid rgba(0,0,0,.05)}.invoice-totals-view{max-width:220px;margin-left:auto;margin-bottom:var(--spacing-md)}.invoice-totals-view>div{display:flex;justify-content:space-between;padding:4px 0;font-size:var(--text-sm)}.invoice-totals-view .total-row{font-weight:600;font-size:var(--text-base);border-top:1px solid rgba(0,0,0,.1);padding-top:8px;margin-top:4px}.invoice-totals-view .paid-row{color:#16a34a}.invoice-totals-view .due-row{color:#f59e0b;font-weight:600}.invoice-notes{font-size:var(--text-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-md);padding:var(--spacing-sm);background:#fff;border-radius:var(--radius-sm)}.next-appointment-hero{display:flex;align-items:center;gap:var(--spacing-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#2c5f4d14,#2c5f4d05);border-left:4px solid var(--color-primary-action)}.hero-icon{font-size:2.5rem}.hero-content{display:flex;flex-direction:column}.hero-label{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:1px;color:var(--color-text-secondary)}.hero-date{font-size:var(--text-2xl);font-weight:700;color:var(--color-primary-action)}.quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.stat-card{background:#fff;border-radius:var(--radius-md);padding:var(--spacing-md);text-align:center;box-shadow:0 2px 8px #0000000a;cursor:pointer;transition:var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.stat-value{display:block;font-size:var(--text-3xl);font-weight:700;color:var(--color-text-primary)}.stat-value.warning{color:#f59e0b}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.messages-alert{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);background:linear-gradient(135deg,#3b82f614,#3b82f605);border:1px solid rgba(59,130,246,.2);cursor:pointer;transition:var(--transition-fast)}.messages-alert:hover{background:#3b82f61a}.alert-icon{font-size:1.5rem}.alert-text{flex:1;font-weight:500;color:#3b82f6}.alert-arrow{font-size:1.2rem;color:#3b82f6}.messages-header{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.back-btn{background:var(--color-bg-off-white);border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-base);transition:var(--transition-fast)}.back-btn:hover{background:var(--color-accent-mint)}.treatment-section h3{margin-bottom:var(--spacing-md);color:var(--color-text-primary)}.treatment-plan-card{margin-bottom:var(--spacing-md)}.plan-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.plan-header h4{margin:0;font-size:var(--text-lg)}.progress-text{font-size:var(--text-sm);color:var(--color-text-secondary)}.treatment-stepper{display:flex;align-items:flex-start;gap:0;overflow-x:auto;padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md)}.stepper-item{display:flex;flex-direction:column;align-items:center;position:relative;min-width:80px;flex:1}.stepper-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--text-sm);z-index:2;transition:var(--transition-fast)}.stepper-item.completed .stepper-dot{background:var(--color-primary-action);color:#fff}.stepper-item.in_progress .stepper-dot{background:#3b82f6;color:#fff;box-shadow:0 0 0 4px #3b82f633}.stepper-item.pending .stepper-dot{background:#e5e7eb;color:#9ca3af}.stepper-label{font-size:11px;text-align:center;margin-top:8px;color:var(--color-text-secondary);max-width:70px;line-height:1.3}.stepper-item.completed .stepper-label,.stepper-item.in_progress .stepper-label{color:var(--color-text-primary);font-weight:500}.stepper-line{position:absolute;top:16px;left:50%;width:100%;height:3px;background:#e5e7eb;z-index:1}.stepper-item.completed .stepper-line{background:var(--color-primary-action)}.current-phase{background:#3b82f60d;padding:var(--spacing-sm);border-radius:var(--radius-sm);border-left:3px solid #3b82f6}.current-phase strong{color:#3b82f6}.current-phase p{margin:4px 0 0;font-size:var(--text-sm);color:var(--color-text-secondary)}.sub-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);background:var(--color-bg-off-white);padding:4px;border-radius:var(--radius-sm)}.sub-tab{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-fast)}.sub-tab:hover{color:var(--color-text-primary)}.sub-tab.active{background:#fff;color:var(--color-primary-action);box-shadow:0 1px 3px #0000001a}.desktop-only{display:flex}.mobile-only{display:none}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;justify-content:space-around;padding:8px 0;padding-bottom:max(8px,env(safe-area-inset-bottom));box-shadow:0 -2px 10px #0000001a;z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;padding:8px 16px;cursor:pointer;position:relative;transition:var(--transition-fast)}.nav-icon{font-size:1.4rem}.nav-label{font-size:10px;font-weight:500;color:var(--color-text-secondary);transition:var(--transition-fast)}.nav-item.active{position:relative}.nav-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:36px;height:3px;background:var(--color-primary-action);border-radius:0 0 3px 3px}.nav-item.active .nav-icon{color:var(--color-primary-action)}.nav-item.active .nav-label{color:var(--color-primary-action);font-weight:600}.nav-badge{position:absolute;top:4px;right:8px;background:#f59e0b;color:#fff;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:16px;text-align:center}@media(max-width:768px){.patient-portal{padding-bottom:80px}.portal-header{flex-direction:column;align-items:flex-start}.portal-header h1{font-size:var(--text-2xl)}.desktop-only{display:none!important}.mobile-only{display:flex!important}.quick-stats{gap:var(--spacing-xs)}.stat-card{padding:var(--spacing-sm)}.stat-value{font-size:var(--text-xl)}.treatment-stepper{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch}.stepper-item{min-width:70px}.next-appointment-hero{padding:var(--spacing-md)}.hero-date{font-size:var(--text-xl)}.status-card{flex-direction:column;gap:var(--spacing-sm);text-align:left}.status-item{text-align:left;display:flex;justify-content:space-between;padding:var(--spacing-xs) 0;border-bottom:1px solid rgba(0,0,0,.05)}.status-item:last-child{border-bottom:none}.appointment-banner{flex-direction:column;text-align:center}.portal-tabs{gap:4px}.portal-tabs .tab-btn{padding:10px 14px;font-size:var(--text-sm)}.files-grid{grid-template-columns:repeat(2,1fr)}.profile-grid{grid-template-columns:1fr}.profile-field.full-width{grid-column:span 1}.treatment-plan-card{padding:var(--spacing-sm)}.plan-card-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.plan-card-header h3{font-size:var(--text-lg)}.phase-row{flex-wrap:wrap;gap:var(--spacing-xs)}.phase-indicator{width:24px;height:24px}.phase-status{margin-top:var(--spacing-xs)}.lightbox-content{max-width:95%;max-height:95%}}@media(max-width:480px){.files-grid{grid-template-columns:1fr}.portal-tabs .tab-btn{padding:8px 10px;font-size:13px}.visit-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}}.receptionist-patient-view{max-width:1200px;margin:0 auto}.patient-header{margin-bottom:var(--spacing-lg)}.patient-header h1{margin:0 0 var(--spacing-xs);color:var(--color-primary);font-family:Georgia,serif}.patient-contact{display:flex;gap:var(--spacing-md);color:var(--color-text-secondary);font-size:var(--text-sm)}.patient-contact span{display:flex;align-items:center;gap:6px}.tabs-nav{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--color-border, #e5e7eb);overflow-x:auto}.tab-btn{display:flex;align-items:center;gap:8px;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;border-bottom:3px solid transparent;font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .2s;white-space:nowrap}.tab-btn:hover{color:var(--color-primary);background:#1b4b430d}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header h3{margin:0;font-size:var(--text-lg);color:var(--color-primary)}.files-section{margin-top:var(--spacing-md)}.upload-form,.schedule-form{margin-bottom:var(--spacing-lg);padding:var(--spacing-lg)}.upload-form h4,.schedule-form h4{margin:0 0 var(--spacing-md);color:var(--color-primary)}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-md)}.file-card{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md)}.file-icon{font-size:2rem;text-align:center}.file-info{flex:1}.file-info h4{margin:0 0 4px;font-size:var(--text-base);color:var(--color-text);word-break:break-word}.file-type{display:inline-block;padding:2px 8px;background:var(--color-accent-mint, #d4edda);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;margin-bottom:8px}.file-info p{font-size:var(--text-sm);color:var(--color-text-secondary);margin:4px 0}.file-date{font-size:var(--text-xs);color:var(--color-text-tertiary)}.appointments-section{margin-top:var(--spacing-md)}.appointments-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.appointment-card{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);gap:var(--spacing-md)}.appointment-info{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.appointment-date{display:flex;align-items:center;gap:8px;color:var(--color-primary)}.appointment-time{font-weight:600;color:var(--color-text)}.appointment-type{padding:4px 12px;background:var(--color-bg-off-white, #f8fafc);border-radius:var(--radius-sm);font-size:var(--text-sm);color:var(--color-text-secondary)}.appointment-status{padding:4px 12px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;text-transform:capitalize}.appointment-status.scheduled{background:#3b82f61a;color:#3b82f6}.appointment-status.confirmed{background:#22c55e1a;color:#22c55e}.appointment-status.checked_in{background:#a855f71a;color:#a855f7}.appointment-status.completed{background:#28a7451a;color:#28a745}.appointment-status.cancelled{background:#ef44441a;color:#ef4444}.walk-in-badge{padding:4px 8px;background:var(--color-accent, #F5E6D3);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.form-group{margin-bottom:var(--spacing-sm)}.form-group label{display:block;margin-bottom:6px;font-size:var(--text-sm);font-weight:600;color:var(--color-text)}.form-group input,.form-group select{width:100%;padding:10px 14px;border:1px solid var(--color-border, #e5e7eb);border-radius:var(--radius-sm);font-size:var(--text-base);font-family:inherit}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #1b4b431a}.form-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border, #e5e7eb)}.empty-state{text-align:center;padding:var(--spacing-xl);color:var(--color-text-secondary)}@media(max-width:768px){.tabs-nav{flex-direction:column;border-bottom:none}.tab-btn{border-bottom:none;border-left:3px solid transparent;justify-content:flex-start}.tab-btn.active{border-left-color:var(--color-primary);border-bottom-color:transparent}.files-grid{grid-template-columns:1fr}.appointment-card{flex-direction:column;align-items:flex-start}.appointment-info{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.form-row{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-sm)}.patient-contact{flex-direction:column;gap:var(--spacing-xs)}}
