*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f0f2f5;color:#1a1a2e;min-height:100vh}.spinner-container{display:flex;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 0}.spinner-text{font-size:14px;color:#888}.spinner{width:36px;height:36px;border:3px solid #e0e0e0;border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:60px;background:linear-gradient(135deg,var(--color-header-start),var(--color-header-end));color:#fff;box-shadow:0 2px 8px #00000026}.header-left{display:flex;align-items:center;gap:12px;cursor:pointer}.header-logo{width:36px;height:36px;background:#fff;color:var(--color-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px}.header-title{font-size:18px;font-weight:600}.header-right{display:flex;align-items:center;gap:16px}.header-user{font-size:14px;opacity:.85}.btn-link{background:none;border:none;color:#fff;cursor:pointer;font-size:14px;text-decoration:underline;opacity:.85}.btn-link:hover{opacity:1}.lang-select{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:4px;padding:2px 5px;font-size:11px;cursor:pointer;outline:none}.lang-select option{color:#1a1a2e;background:#fff}.header-user-menu{position:relative}.header-user-btn{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:4px 10px 4px 4px;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s;white-space:nowrap}.header-user-btn:hover{background:#fff3}.header-avatar{width:32px;height:32px;border-radius:50%;background:#ffffff40;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.header-user-info{display:flex;flex-direction:column;line-height:1.2;min-width:0}.header-user-email{font-size:12px;font-weight:600;opacity:.95}.header-user-practice{font-size:11px;opacity:.7;max-width:160px;overflow:hidden;text-overflow:ellipsis}.header-user-role{font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.header-user-role.role-super{background:#ffffff40;color:#fff}.header-user-role.role-admin{background:#ffc8324d;color:#fff}.header-user-role.role-user{background:#ffffff26;color:#ffffffd9}.header-user-arrow{font-size:9px;opacity:.6}.header-menu-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;z-index:99}.header-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 8px 30px #0000002e;min-width:220px;z-index:100;overflow:hidden;padding:4px 0}.header-menu-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 16px;background:none;border:none;text-align:left;font-size:14px;color:#333;cursor:pointer;transition:background .15s}.header-menu-item:hover{background:#f5f5f5}.header-menu-item.danger{color:#c0392b}.header-menu-item.danger:hover{background:#fdecea}.header-menu-arrow{font-size:10px;opacity:.5;margin-left:8px}.header-menu-role-row{padding:10px 16px}.header-menu-role-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:10px;text-transform:uppercase;letter-spacing:.3px}.header-menu-role-badge.role-super{background:color-mix(in srgb,var(--color-primary) 12%,white);color:var(--color-primary)}.header-menu-role-badge.role-admin{background:#fef5e7;color:#e67e22}.header-menu-role-badge.role-user{background:#f0f0f0;color:#666}.header-menu-divider{height:1px;background:#eee;margin:4px 0}.header-menu-practice-group{position:relative}.header-menu-practices{border-top:1px solid #f0f0f0;background:#fafafa}.header-menu-practice-item{display:block;width:100%;padding:9px 16px 9px 28px;background:none;border:none;text-align:left;font-size:13px;color:#555;cursor:pointer;transition:background .15s}.header-menu-practice-item:hover{background:#f0f0f0}.header-menu-practice-item.active{color:var(--color-primary);font-weight:600;background:color-mix(in srgb,var(--color-primary) 8%,#fafafa)}.login-page{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 60px);padding:24px}.login-card{background:#fff;border-radius:12px;padding:48px 40px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000014;text-align:center}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--color-header-start),var(--color-header-end));color:#fff;border-radius:16px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:32px;margin:0 auto 16px}.login-card h1{font-size:24px;color:#1a1a2e;margin-bottom:4px}.login-subtitle{color:#666;margin-bottom:32px;font-size:14px}.form-group{margin-bottom:16px;text-align:left}.form-group label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:6px}.form-group input{width:100%;padding:12px 14px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:border-color .2s;background:#fafafa}.form-group input:focus{outline:none;border-color:var(--color-primary);background:#fff}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.btn-primary{width:100%;padding:14px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .2s}.btn-primary:hover{opacity:.9}.login-card .btn-link{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;text-decoration:underline;margin-top:12px;padding:4px;width:100%}.login-card .btn-link:hover{opacity:.8}.totp-qr{display:flex;justify-content:center;margin:16px 0}.totp-qr img{width:200px;height:200px;border:1px solid #e5e7eb;border-radius:8px;padding:8px;background:#fff}.totp-secret{display:block;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;padding:10px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px;text-align:center;word-break:break-all}.totp-help{color:#6b7280;font-size:13px;margin:4px 0 10px}.totp-recovery-list{list-style:none;padding:12px;margin:0 0 10px;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:grid;grid-template-columns:1fr 1fr;gap:6px}.totp-recovery-list code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:13px}.totp-ack{display:flex;align-items:center;gap:8px;font-size:13px;color:#374151}.totp-ack input{width:auto}.invoices-page{max-width:720px;margin:0 auto;padding:32px 24px}.page-header{margin-bottom:24px}.page-header h2{font-size:22px;margin-bottom:4px}.page-header p{color:#666;font-size:14px}.invoices-list{display:flex;flex-direction:column;gap:12px}.search-bar{margin-bottom:20px}.search-bar input{width:100%;padding:14px 16px;border:1px solid #ddd;border-radius:10px;font-size:16px;background:#fff;box-shadow:0 2px 8px #0000000a;transition:border-color .2s}.search-bar input:focus{outline:none;border-color:var(--color-primary)}.client-list{display:flex;flex-direction:column;gap:10px}.client-card{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:10px;padding:18px 24px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:box-shadow .2s,transform .15s;border:1px solid #eee}.client-card:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.client-card-info{display:flex;flex-direction:column;gap:4px}.client-name{font-size:16px;font-weight:600;color:#1a1a2e}.client-contact{font-size:13px;color:#888}.client-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.client-invoice-count{font-size:13px;font-weight:600;color:#c0392b;background:#fdecea;padding:3px 10px;border-radius:12px}.no-results{text-align:center;color:#888;padding:32px 0}.invoice-card{background:#fff;border-radius:10px;padding:20px 24px;box-shadow:0 2px 8px #0000000f;cursor:pointer;transition:box-shadow .2s,transform .15s;border:1px solid #eee}.invoice-card:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.invoice-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.invoice-number{font-weight:700;color:var(--color-primary);font-size:14px}.invoice-status{font-size:12px;font-weight:600;color:#c0392b;background:#fdecea;padding:3px 10px;border-radius:12px}.invoice-card-body{margin-bottom:12px}.invoice-description{font-size:15px;font-weight:500;margin-bottom:4px}.invoice-date{font-size:13px;color:#888}.invoice-card-footer{display:flex;justify-content:space-between;align-items:center}.invoice-amount{font-size:20px;font-weight:700;color:#1a1a2e}.invoice-pay-link{font-size:14px;color:var(--color-primary);font-weight:600}.payment-page{display:flex;justify-content:center;padding:32px 24px}.payment-card{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:480px;box-shadow:0 4px 24px #00000014}.btn-back{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;font-weight:600;padding:0;margin-bottom:20px}.btn-back:hover{text-decoration:underline}.payment-summary{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid #eee}.payment-summary h2{font-size:20px;margin-bottom:6px}.payment-description{color:#666;font-size:14px;margin-bottom:16px}.payment-amount-display{display:flex;justify-content:space-between;align-items:center;background:color-mix(in srgb,var(--color-primary) 6%,white);padding:14px 18px;border-radius:8px}.payment-amount-display span:first-child{font-size:14px;color:#666}.amount-value{font-size:24px;font-weight:700;color:var(--color-primary)}.payment-amount-section{display:flex;flex-direction:column;gap:12px}.pay-amount-input label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:4px}.amount-input-wrapper{display:flex;align-items:center;border:1px solid #ddd;border-radius:8px;background:#fafafa;overflow:hidden;transition:border-color .2s}.amount-input-wrapper:focus-within{border-color:var(--color-primary);background:#fff}.amount-prefix{padding:10px 0 10px 14px;font-size:18px;font-weight:700;color:#333}.amount-input-wrapper input{flex:1;padding:10px 14px 10px 4px;border:none;background:transparent;font-size:18px;font-weight:700;color:#1a1a2e;outline:none}.amount-input-wrapper input::-webkit-inner-spin-button,.amount-input-wrapper input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.amount-input-wrapper input[type=number]{-moz-appearance:textfield}.amount-error{display:inline-block;margin-top:6px;font-size:13px;font-weight:600;color:#c0392b}.partial-badge{display:inline-block;margin-top:6px;font-size:13px;font-weight:600;color:#e67e22;background:#fef5e7;padding:4px 10px;border-radius:8px}.error-banner{background:#fdecea;color:#c0392b;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:14px}.cc-form h3{font-size:16px;margin-bottom:16px;color:#333}.btn-pay{width:100%;padding:14px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .2s}.btn-pay:hover:not(:disabled){opacity:.9}.btn-pay:disabled{opacity:.6;cursor:not-allowed}.terminal-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:#999;font-size:13px}.terminal-divider:before,.terminal-divider:after{content:"";flex:1;height:1px;background:#ddd}.terminal-section{margin-top:4px}.btn-terminal{width:100%;display:flex;align-items:center;gap:14px;padding:16px 20px;background:#1a1d21;color:#e0e0e0;border:1px solid #333;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:border-color .2s,box-shadow .2s;font-family:SF Mono,Fira Code,Consolas,monospace}.btn-terminal:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),0 4px 12px #0003}.btn-terminal:disabled{opacity:.5;cursor:not-allowed}.terminal-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#2a2d31;border-radius:8px;font-size:20px;color:var(--color-primary);border:1px solid #3a3d41}.terminal-label{flex:1;text-align:left}.terminal-status{font-size:12px;color:var(--color-primary);background:#00d0841a;padding:3px 10px;border-radius:10px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.remote-pay-options{display:flex;flex-direction:column;gap:12px}.remote-pay-row{display:flex;gap:10px;align-items:flex-end}.remote-pay-input{flex:1}.remote-pay-input label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:4px}.remote-pay-input input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;background:#fafafa;transition:border-color .2s}.remote-pay-input input:focus{outline:none;border-color:var(--color-primary);background:#fff}.btn-text-to-pay,.btn-email-to-pay{padding:10px 16px;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .2s}.btn-text-to-pay{background:var(--color-primary)}.btn-email-to-pay{background:var(--color-header-start)}.btn-text-to-pay:hover:not(:disabled),.btn-email-to-pay:hover:not(:disabled){opacity:.9}.btn-text-to-pay:disabled,.btn-email-to-pay:disabled{opacity:.6;cursor:not-allowed}.success-card{text-align:center}.success-icon{width:64px;height:64px;background:#27ae60;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px}.success-card h2{color:#27ae60;margin-bottom:8px}.success-card p{color:#444;margin-bottom:4px}.success-detail{color:#888!important;font-size:14px;margin-bottom:24px!important}.success-card .btn-primary{margin-top:16px}.admin-page{max-width:720px;margin:0 auto;padding:32px 24px}.admin-tabs{display:flex;gap:0;margin-bottom:24px;border-bottom:2px solid #eee}.admin-tab{padding:10px 20px;background:none;border:none;font-size:14px;font-weight:600;color:#888;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .2s,border-color .2s}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.admin-tab:hover{color:#444}.admin-filter-bar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px}.admin-filter-bar .btn-primary{width:auto;padding:8px 16px;font-size:13px;margin-top:0;white-space:nowrap}.admin-form{background:#fff;border-radius:10px;padding:24px;margin-bottom:20px;box-shadow:0 2px 8px #0000000f;border:1px solid #eee}.admin-form h3{font-size:16px;margin-bottom:16px;color:#333}.admin-section{margin-bottom:24px}.admin-section h2{font-size:22px;margin-bottom:4px}.admin-section h3{font-size:16px;margin-bottom:12px;color:#333}.admin-subtitle{color:#888;font-size:13px;font-family:monospace}.admin-list{display:flex;flex-direction:column;gap:10px}.admin-list-item{display:flex;justify-content:space-between;align-items:center;background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 2px 8px #0000000f;border:1px solid #eee}.admin-list-item.clickable{cursor:pointer;transition:box-shadow .2s,transform .15s}.admin-list-item.clickable:hover{box-shadow:0 4px 16px color-mix(in srgb,var(--color-primary) 12%,transparent);transform:translateY(-1px)}.admin-list-info{display:flex;flex-direction:column;gap:2px}.admin-list-name{font-size:15px;font-weight:600;color:#1a1a2e;display:flex;align-items:center;gap:8px}.admin-list-detail{font-size:13px;color:#888}.super-badge{font-size:11px;font-weight:600;color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,white);padding:2px 8px;border-radius:10px}.admin-inline-form{display:flex;gap:10px;align-items:center}.select-wrapper{position:relative;flex:1}.styled-select{width:100%;padding:10px 36px 10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff;color:#333;cursor:pointer;-moz-appearance:none;appearance:none;-webkit-appearance:none;transition:border-color .2s,box-shadow .2s,background .15s}.styled-select:hover{border-color:#bbb;background:#fafafa}.styled-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,transparent);background:#fff}.select-arrow{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;color:#888;pointer-events:none}.admin-select{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fff}.admin-select:focus{outline:none;border-color:var(--color-primary)}.btn-primary-sm{padding:10px 18px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-end));color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;white-space:nowrap}.btn-primary-sm:hover:not(:disabled){opacity:.9}.btn-primary-sm:disabled{opacity:.6;cursor:not-allowed}.btn-danger-sm{padding:6px 14px;background:#fdecea;color:#c0392b;border:1px solid #f5c6cb;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.btn-danger-sm:hover{background:#f8d7da}.admin-badge{font-size:11px;font-weight:600;color:#e67e22;background:#fef5e7;padding:2px 8px;border-radius:10px}.user-badge{font-size:11px;font-weight:600;color:#666;background:#f0f0f0;padding:2px 8px;border-radius:10px}.admin-list-item.revoked{opacity:.55}.revoked-badge{font-size:11px;font-weight:600;color:#c0392b;background:#fdecea;padding:2px 8px;border-radius:10px}.pending-badge{font-size:11px;font-weight:600;color:#92400e;background:#fef3c7;padding:2px 8px;border-radius:10px}.user-actions-menu{position:relative;opacity:0;transition:opacity .15s}.user-list-item:hover .user-actions-menu{opacity:1}.user-actions-trigger{background:none;border:none;font-size:20px;color:#888;cursor:pointer;padding:4px 8px;border-radius:6px;line-height:1;transition:background .15s,color .15s}.user-actions-trigger:hover{background:#f0f0f0;color:#333}.user-actions-dropdown{display:none;position:absolute;right:0;top:100%;padding-top:4px;min-width:170px;z-index:10}.user-actions-dropdown-inner{background:#fff;border-radius:8px;box-shadow:0 4px 16px #0000001f;overflow:hidden}.user-actions-menu:hover .user-actions-dropdown{display:block}.user-actions-dropdown-inner button{display:block;width:100%;padding:9px 14px;background:none;border:none;text-align:left;font-size:13px;color:#333;cursor:pointer;transition:background .12s}.user-actions-dropdown-inner button:hover{background:#f5f5f5}.user-actions-dropdown-inner button.danger{color:#c0392b}.user-actions-dropdown-inner button.danger:hover{background:#fdecea}.role-select{width:120px;flex:none}.admin-filter-select{max-width:240px}.admin-section-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.btn-secondary-sm{padding:6px 14px;background:#f0f0f0;color:#333;border:1px solid #ddd;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary-sm:hover{background:#e0e0e0}.btn-secondary{padding:10px 20px;background:#f0f0f0;color:#333;border:1px solid #ddd;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s}.btn-secondary:hover{background:#e0e0e0}.terminals-section{margin-top:8px;margin-bottom:12px}.terminals-section>label,.terminals-header>label{font-size:14px;font-weight:600;color:#555;margin-bottom:8px;display:block}.terminal-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}.terminal-row input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#fafafa}.terminal-row input:focus{outline:none;border-color:var(--color-primary);background:#fff}.terminal-row .btn-danger-sm:disabled{opacity:.4;cursor:not-allowed}.edit-actions{display:flex;gap:10px;margin-top:16px}.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:20px}.modal-content{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.modal-header h3{font-size:18px;font-weight:700;color:#1a1a2e;margin:0}.modal-close{background:none;border:none;font-size:24px;color:#888;cursor:pointer;padding:0 4px;line-height:1}.modal-close:hover{color:#333}.modal-actions{display:flex;gap:10px;margin-top:20px}.suggest-input{position:relative;flex:1}.suggest-input input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;background:#fafafa;transition:border-color .2s}.suggest-input input:focus{outline:none;border-color:var(--color-primary);background:#fff}.suggest-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 16px #0000001a;z-index:10;overflow:hidden}.suggest-option{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border:none;background:none;cursor:pointer;font-size:14px;text-align:left;transition:background .15s}.suggest-option:hover{background:#f5f5f5}.suggest-value{color:#1a1a2e}.suggest-label{font-size:12px;color:#888;text-transform:capitalize}.suggest-empty{padding:10px 14px;font-size:13px;color:#aaa;text-align:center}
