:root{--color-primary: #20B2AA;--color-primary-dark: #179085;--color-accent: #1A1A40;--color-bg: #f0f8ff;--color-surface: #ffffff;--color-border: #e9ecef;--color-text: #1f2a37;--color-muted: #6b7280;--color-danger: #e55353;--color-warning: #f0ad4e;--color-success: #22c55e;--color-info: #0ea5e9;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 8px 22px rgba(0,0,0,.1);--shadow-lg: 0 14px 36px rgba(0,0,0,.14);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.45;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}input,textarea,select,button{font:inherit}.container{max-width:1120px;margin:0 auto;padding:0 var(--space-4)}h1,h2,h3,h4{margin:var(--space-3) 0;line-height:1.2}h1{font-size:2rem;color:var(--color-primary)}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.1rem;color:var(--color-muted)}.small{font-size:.875rem;color:var(--color-muted)}.muted{color:var(--color-muted)}.center{text-align:center}.right{text-align:right}.avatar-circle{width:96px;height:96px;border-radius:50%;display:grid;place-items:center;background:#008b8b;color:#fff;font-weight:800;font-size:28px;-webkit-user-select:none;user-select:none;box-shadow:var(--shadow-sm)}.field-with-addon{position:relative}.field-addon{position:absolute;top:6px;right:6px;display:flex;gap:6px}.alert{padding:10px 12px;border-radius:var(--radius-sm);background:#f8fafc;border:1px solid var(--color-border)}.alert.success{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.alert.error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.alert.info{background:#eff6ff;border-color:#bfdbfe;color:#1e3a8a}.landing-container{width:100%;min-height:100vh;display:grid;place-items:center;padding:var(--space-8) var(--space-4)}.landing-content{width:100%;max-width:680px;text-align:center;background:var(--color-surface);padding:var(--space-8);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.logo-landing{width:100px;height:100px;object-fit:contain;margin-bottom:var(--space-4)}.landing-content .subtitle{font-size:1.1rem;color:var(--color-muted);margin-top:var(--space-1)}.landing-content p{font-size:1rem;line-height:1.65;margin:var(--space-5) 0}.landing-actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.login-container{width:100%;min-height:100vh;display:grid;place-items:center;padding:var(--space-8) var(--space-4)}.login-box{width:100%;max-width:480px;background:var(--color-surface);padding:var(--space-8);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.header{text-align:center;margin-bottom:var(--space-6)}.header h1{color:var(--color-primary);margin:var(--space-2) 0 0 0;font-size:28px}.header p{color:var(--color-muted);margin:var(--space-1) 0 0 0}.logo-minimalista{width:50px;height:50px;object-fit:contain}.login-logo{display:block;margin:0 auto var(--space-4);width:88px;height:auto}.login-form .input-group{margin-bottom:var(--space-5)}.input-group label{display:block;margin-bottom:var(--space-2);font-weight:600}.input-group input,.input-group textarea,.search-bar input{width:100%;padding:12px 14px;border:1px solid #d1d5db;border-radius:var(--radius-sm);font-size:16px;transition:border-color .2s,box-shadow .2s;background:#fff}.input-group input:focus,.input-group textarea:focus,.search-bar input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #20b2aa1f}.error-message{color:var(--color-danger);font-size:14px;text-align:center;margin:0 0 var(--space-3)}.cashback-preview{background:var(--color-bg);padding:var(--space-3);border-radius:var(--radius-sm);margin-top:var(--space-2);text-align:center;border:1px dashed var(--color-border)}.back-button{background:none;border:none;color:var(--color-primary);font-size:15px;cursor:pointer;margin-top:var(--space-3)}.back-button:hover{text-decoration:underline}button{cursor:pointer}button:disabled{opacity:.7;cursor:not-allowed}.cta-button,.login-button,.btn,.btn-primary,.btn-outline,.btn-danger,.btn-quiet,.btn-warning{padding:12px 18px;border-radius:var(--radius-sm);border:1px solid transparent;font-weight:700;transition:background-color .2s,box-shadow .2s,border-color .2s,transform .05s}.cta-button{background:var(--color-primary);color:#fff}.cta-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.cta-button.secondary{background:#eef2f7;color:var(--color-text);border-color:#e2e8f0}.cta-button.secondary:hover{background:#e6edf5}.login-button,.btn-primary{background:#1fa49a;color:#fff;box-shadow:0 2px 6px #1fa49a2e}.login-button:hover,.btn-primary:hover{background:#179085}.btn-outline{background:#fff;color:#1f2a37;border-color:#0000001f}.btn-outline:hover{border-color:#00000038}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#d94a4a}.btn-warning{background:var(--color-warning);color:#1f2937;border-color:#0000000f;box-shadow:var(--shadow-sm)}.btn-warning:hover{background:#e19d40}.saldo-destaque .btn-warning{padding:8px 14px;font-size:.875rem;border-radius:999px;background:linear-gradient(#f7c66d,var(--color-warning));box-shadow:0 2px 6px #00000014}.saldo-destaque .btn-warning:hover{background:linear-gradient(#f3b954,#e19d40);transform:translateY(-1px)}.btn-quiet{background:#f3f7f7;color:#0f766e;border:1px solid #E1EFEF}.btn-quiet:hover{background:#e8f1f1}.btn-outline-link{display:inline-block;font-size:14px;font-weight:600;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);padding:8px 14px;border-radius:var(--radius-sm);text-decoration:none}.btn-outline-link:hover{background:var(--color-primary);color:#fff;text-decoration:none}.button-row{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.button-row.subtle{margin-top:var(--space-3)}.button-row.ctas{margin-top:var(--space-4)}.action-button{padding:12px 18px;border-radius:var(--radius-sm);border:none;color:#fff;font-weight:700}.action-button.credit{background:var(--color-success)}.action-button.debit{background:var(--color-warning);color:#1f2937}.action-button.edit{background:#0284c7}.action-button.delete{background:var(--color-danger)}.dashboard-container{max-width:1000px;margin:var(--space-8) auto;padding:var(--space-8);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.header-title-group{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.header-logo{width:40px;height:40px;object-fit:contain}.logout-button{padding:10px 16px;border:none;border-radius:var(--radius-sm);background:var(--color-danger);color:#fff;font-weight:700}.logout-button:hover{background:#c9302c}.search-bar{flex-grow:1}.admin-actions-bar{display:flex;gap:var(--space-4);align-items:center;margin:var(--space-5) 0}.admin-actions{display:flex;gap:var(--space-3)}.patient-list{list-style:none;padding:0;margin:0}.patient-list li{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:var(--space-3);cursor:pointer;transition:background-color .2s,box-shadow .2s,border-color .2s}.patient-list li:hover{background:#f9fafb;box-shadow:var(--shadow-sm)}.patient-list-info{flex:1;display:flex;align-items:center;gap:var(--space-2)}.patient-list-info span{font-weight:700;display:block}.patient-list-info small{color:var(--color-muted)}.profile-pic-small{width:40px;height:40px;border-radius:50%;background:#008b8b;color:#fff;display:grid;place-items:center;font-weight:800;font-size:14px;flex-shrink:0;box-shadow:var(--shadow-sm)}.profile-pic-large{width:80px;height:80px;border-radius:50%;object-fit:cover;box-shadow:var(--shadow-sm)}.patient-details-header{display:flex;gap:var(--space-5);align-items:center;margin-bottom:var(--space-4)}.patient-info p{margin:4px 0}.saldo-destaque{background:#f7feff;border:1px solid var(--color-primary);color:var(--color-primary);padding:var(--space-4);border-radius:var(--radius-sm);font-size:20px;font-weight:800;text-align:center;margin:var(--space-4) 0}.transaction-list{list-style:none;padding:0;margin:0}.transaction-list li{display:flex;justify-content:space-between;gap:var(--space-3);padding:10px 12px;border-bottom:1px solid #eef1f4}.transaction-list li.credito span:last-child{color:var(--color-success);font-weight:700}.transaction-list li.debito span:last-child{color:var(--color-danger);font-weight:700}.inconsistency-warning{background:#fcf8e3;border:1px solid #faebcc;color:#8a6d3b;padding:var(--space-4);border-radius:var(--radius-sm);margin:var(--space-4) 0;text-align:center}.dashboard-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4)}.dashboard-tabs button{flex:1;padding:var(--space-4);background:none;border:none;cursor:pointer;color:#6b7280;font-weight:700;border-bottom:3px solid transparent;transition:color .2s,border-color .2s,background .2s}.dashboard-tabs button:hover{background:#f8fafc}.dashboard-tabs button.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content{padding-top:var(--space-4)}.admin-dashboard-embedded{padding:0;box-shadow:none;border-radius:0}.procedimento-list{list-style:none;padding:0;margin:0}.procedimento-list li{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:var(--space-3)}.procedimento-list li.inativo{background:#f9f9f9;opacity:.6}.procedimento-info{flex:1}.procedimento-info span{font-weight:700;display:block}.procedimento-info small{color:var(--color-muted)}.procedimento-descricao{font-size:14px;color:var(--color-muted);margin-top:var(--space-2)}.patient-portal,.portal-layout{display:flex;gap:var(--space-6);align-items:stretch}.portal-sidebar,.patient-portal .sidebar,.patient-portal .left-panel{width:280px;min-width:240px;max-width:320px;padding:24px 20px;display:flex;flex-direction:column;align-items:center;border-right:1px solid rgba(0,0,0,.06);background:#f8f9fa;border-radius:var(--radius-lg)}.portal-sidebar .brand,.patient-portal .sidebar .brand{width:100%;display:flex;justify-content:center;margin-bottom:var(--space-2)}.portal-sidebar .brand img,.patient-portal .sidebar .brand img,.logo-sidebar{height:28px;width:auto;display:block}.patient-portal .greeting{margin:6px 0 14px;text-align:center;color:#2d3748;font-size:14px}.patient-portal .greeting+.soft-sep{width:100%;height:1px;background:#0000000f;margin:12px 0 8px;border-radius:1px}.patient-portal .menu{margin-top:6px;width:100%;display:flex;flex-direction:column;gap:12px}.patient-portal .menu button{width:100%;text-align:left;padding:10px 14px;border-radius:10px;border:1px solid rgba(0,0,0,.1);background:#fff;color:var(--color-text);cursor:pointer}.patient-portal .menu button.active{background:#20a090;color:#fff;border-color:transparent}.patient-portal .menu .danger{background:var(--color-danger);color:#fff;border-color:transparent}.portal-content,.patient-portal .content,.patient-portal .right-panel{flex:1;padding:24px}.portal-content .card,.patient-portal .content .card{margin:0 auto;max-width:820px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm)}.modal-overlay{position:fixed;inset:0;background:#0009;display:grid;place-items:center;z-index:1000}.modal-content{width:92%;max-width:540px;background:var(--color-surface);padding:var(--space-6);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-border);padding-bottom:var(--space-3);margin-bottom:var(--space-4)}.modal-close-button{background:none;border:none;font-size:28px;color:#888;cursor:pointer}.modal-confirm-button{width:100%;padding:15px;margin-top:var(--space-4);border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-weight:700}.modal-confirm-button:disabled{background:#a3a3a3;cursor:not-allowed}.procedimentos-list{max-height:220px;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-3);margin:var(--space-4) 0}.procedimento-item{display:flex;align-items:center;padding:8px}.procedimento-item input{margin-right:10px}.procedimento-item label{width:100%;cursor:pointer}.resgate-summary{margin-top:var(--space-4);padding:var(--space-4);background:#f8f9fa;border-radius:var(--radius-sm)}.resgate-summary h4{margin-top:0}.resgate-summary p{display:flex;justify-content:space-between;margin:5px 0}.desconto-valor{color:var(--color-danger)}.valor-final{font-size:1.1rem;font-weight:800;border-top:1px solid #ddd;padding-top:10px;margin-top:10px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:var(--space-5)}.list-clean{list-style:none;padding:0;margin:0}.divider{height:1px;background:var(--color-border);margin:var(--space-4) 0;border-radius:1px}.regulamento-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:25px}.regulamento-section{margin-top:var(--space-4)}.regulamento-title{margin:0 0 var(--space-3);color:var(--color-primary);font-size:1.1rem;border-bottom:1px solid var(--color-border);padding-bottom:6px}.regulamento-list{margin:var(--space-3) 0 0 var(--space-6);padding-left:0}.regulamento-list li{margin-bottom:8px}.regulamento-exemplo{margin-top:var(--space-3);background:var(--color-bg);border:1px solid #cfe8f3;color:#155b75;padding:12px 15px;border-radius:var(--radius-sm);font-size:14px}.faq-list{display:flex;flex-direction:column;gap:10px;margin-top:15px}.faq-item{border:1px solid var(--color-border);border-radius:10px;overflow:hidden;background:#fafafa}.faq-item.open{background:#f8fffe;border-color:#cfe8f3}.faq-question{width:100%;display:flex;justify-content:space-between;gap:10px;border:none;background:transparent;text-align:left;padding:15px;font-weight:600;cursor:pointer;font-size:1em}.faq-icon{font-size:20px;line-height:1}.faq-answer{padding:0 15px 15px;color:#444;line-height:1.6}.sr-only,.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}:focus-visible{outline:3px solid rgba(32,178,170,.35);outline-offset:2px}@media (max-width: 900px){.patient-portal,.portal-layout{flex-direction:column}.portal-sidebar,.patient-portal .sidebar,.patient-portal .left-panel{width:100%;max-width:none;border-right:0;border-bottom:1px solid rgba(0,0,0,.06)}.portal-content,.patient-portal .content,.patient-portal .right-panel{padding:var(--space-4)}.landing-content{padding:var(--space-6)}.dashboard-container{margin:var(--space-6) auto;padding:var(--space-6)}}@media (max-width: 560px){.login-box{padding:var(--space-6)}.button-row{flex-direction:column}.dashboard-header{flex-direction:column;gap:var(--space-3);align-items:flex-start}}.patient-details-header{justify-content:center;text-align:center}.patient-details-header .patient-info{text-align:center}.patient-details-header .button-row,.patient-details-header .patient-actions{justify-content:center}.patient-details-header{max-width:760px;margin-left:auto;margin-right:auto}@media (max-width: 560px){.patient-details-header{gap:16px}}.procedimento-list li .btn,.procedimento-list li .action-button,.procedimento-list li button{margin-right:10px}.procedimento-list li .btn:last-child,.procedimento-list li .action-button:last-child,.procedimento-list li button:last-child{margin-right:0}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
